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PHP 语言 具有 简单 性 .开放 性 、 低 成 本 ,安全 性 和 开源 免费 等 诸多 优点 ,适用 Linux 和 
Windows 平台 ,而 且 经 过 发 展 目前 已 经 很 成 熟 ,已 经 成 为 当今 最 流行 的 Web 开发 语言 。 全 
世界 很 多 网 站 均 采 用 PHP 开发 而 成 。 

目前 ,市 场 上 介绍 有 关 PHP 开发 的 书 不 少 ,但 适合 作为 高 等 学 校 PHP 教材 的 书 并 不 
多 。 本 书 以 WampServer( 即 基于 Windows 平台 的 Apache、MySQL、PHP 的 组 合 ) 为 编译 
器 ,结合 编者 多 年 的 项 目 开 发 经 验 以 及 丰富 的 教学 经 验 , 详 细 介 绍 了 PHP 5. 5 的 基础 知识 、 
特点 和 具体 的 应 用 。 全 书 分 为 10 章 , 内 容 包 括 PHP 开发 环境 .PHP 语言 基础 .PHP 数组 
与 字符 串 `.PHP 面向 对 象 程序 设计 、 构 建 PHP 互动 网 页 、MySQL 数据 库 基础 .PHP 访问 
MySQL 数据 库 .PHP 常用 功能 模块 .PHP 安全 编程 .学 生 学 籍 成 绩 管 理 系统 开发 实例 。 学 
生 学 籍 成 绩 管 理 系 统 开发 实例 通过 开发 一 个 实用 系统 来 阐述 PHP 的 开发 技术 和 技巧 。 本 
书 按照 软件 产品 开发 的 规范 与 流程 ,对 系统 进行 需求 分 析 、 数 据 库 设 计 以 及 功能 模块 的 划 
分 ,有 利于 读者 了 解 一 个 实际 项 目的 开发 流程 。 

本 书 内 容 的 讲解 由 浅 入 深 , 循 序 渐 进 ,通俗 易 懂 ,适合 自学 ,力求 具有 实用 性 .可 操作 性 。 
书 中 对 每 个 知识 点 都 有 实例 演示 ,有 助 于 读者 理解 概念 、. 巩 固 知识 .掌握 要 点 、 攻 克 难 点 。 在 
每 章 后 精心 设计 了 2 一 4 道 较为 实用 的 实 训 题 ,进一步 检验 学 生 对 各 个 知识 点 的 综合 应 用 能 
力 。 书 中 所 有 实例 程序 均 上 机 调试 通过 ,通过 阅读 本 书 , 结 合 上 机 实 训 , 读 者 就 能 在 较 短 的 
时 间 内 基本 掌握 PHP 及 其 应 用 技术 。 

本 书 可 作为 高 职 院 校 ,独立 学 院 信息 工 程 类 专业 的 教学 用 书 ,也 可 作为 PHP 网 站 开发 
人 员 的 自学 参考 书 和 相关 培训 班 的 教学 用 书 。 
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思考 与 练习 … 


办 村， 六 才 与 让 卫 从 守 
a 


PHP 是 多 种 开发 动态 网 站 语言 之 一 ,适合 于 开发 规模 为 中 、 小 型 企业 级 的 动态 网 站 , 它 
也 是 当前 比较 流行 的 微 信 后 台 开发 语言 之 一 。 若 要 开发 PHP 项 目 ,必须 选 好 开发 环境 。 
PHP 开发 环境 可 分 为 两 大 类 ,一 类 是 分 立 组 件 的 开发 环境 ,安装 较 麻 烦 但 是 个 性 化 较 强 ; 
另 一 类 是 集成 开发 环境 ,容易 安装 。 本 章 首先 介绍 集成 开发 环境 ,然后 给 出 几 个 典型 PHP 
程序 实例 ,让 读者 对 PHP 有 一 个 初步 的 印象 。 


GE ooee 


。 了 解 几 种 常见 的 动态 网 页 开发 技术 。 
。 掌握 PHP 集成 开发 环境 的 安装 与 使 用 。 
。 掌握 PHP 程序 的 编写 步骤 。 


1.1 PHP 简介 


PHP 是 一 种 适合 于 开发 规模 为 中 .小 企业 级 的 动态 网 站 的 解释 性 程序 语言 。 使 用 
PHP 除了 可 以 开发 动态 网 站 之 外 ,还 是 目前 比较 流行 的 微 信 的 后 台 开发 语言 之 一 ,具有 广 
泛 的 应 用 前 景 。 


1.1.1 静态 网 页 和 动态 网 页 


想必 大 家 都 上 网 浏览 过 网 页 吧 ? 大 家 有 没有 发 现 这 样 一 个 现象 : 有 的 网 页 这 次 看 到 的 
内 容 与 上 一 次 看 到 的 内 容 不 完全 相同 ,例如 新 浪 新 闻 网 页 、 某 政府 门户 网 站 等 ;而 另 一 些 网 
页 则 很 少 改变 ,几乎 每 次 去 看 都 是 同一 个 内 容 , 例 如 百度 网 站 的 首页 、 某 公司 网 站 中 的 联系 
方式 的 页 面 。 下 面 从 几 个 不 同 角度 来 说 明 静 态 网 页 与 动态 网 页 的 概念 。 

从 内 容 的 角度 来 看 ,几乎 一 成 不 变 的 网 页 属于 静态 网 页 ,而 经 常 改变 的 网 页 属于 动态 网 
页 。 从 开发 语言 来 看 ,纯粹 采用 HTML 作为 开发 语言 的 网 页 属于 静态 网 页 ,而 采用 其 他 动 
态 开发 语言 (例如 PHP) 来 开发 的 网 页 属于 动态 网 页 。 从 网 页 文件 是 否 需要 动态 服务 器 解 
析 执 行 的 角度 来 看 ,不 需要 动态 服务 器 解析 执行 的 网 页 称 为 静态 网 页 ,而 需要 动态 服务 器 解 
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析 执 行 的 网 页 称 为 动态 网 页 。 

换 句 话说 ,静态 网 页 中 只 有 HTML 标记 ,没有 其 他 可 执行 的 程序 代码 。 页 面 一 经 制作 
完成 ,其 内 容 就 不 会 再 变化 ,静态 网 页 的 扩展 名 一 般 为 . htm 或 . html。 动 态 网 页 是 指 * 具 有 
交互 性 的 页 面 ", 即 在 网 页 源 代码 不 变 的 情况 下 ,网 页 的 内 容 可 根据 访问 者 \ 访 问 时 间或 者 访 
问 目 的 的 不 同 而 显示 不 同 的 内 容 ,如 留言 板 和 聊天 室 等 。 动 态 网 页 的 扩展 名 一 般 为 . asp、 
.jsp、 php、aspx。 

静态 网 页 与 动态 网 页 的 概念 不 是 绝对 的 ,而 是 相对 的 。 实 际 上 ,采用 动态 开发 语言 (如 
PHP) 也 可 以 开发 出 一 个 一 成 不 变 的 网 页 ,但 这 种 网 页 习惯 上 仍 被 称 为 动态 网 页 ,因为 它 需 
要 经 过 动态 服务 器 解析 执行 。 另 外 ,有 的 网 页 界面 上 有 Flash 动画 、 视 频 等 ,看 起 来 也 是 不 
断 变化 的 ,但 是 ,实际 上 再 过 一 段 时 间 重 新 打开 这 个 网 页 时 看 到 的 内 容 仍然 与 上 次 相同 ,这 
样 的 网 页 则 属于 静态 网 页 。 


1.1.2 动态 网 页 设计 技术 


目前 比较 关注 的 动态 网 页 设计 技术 主要 有 以 下 几 种 。 

(1) ASP。ASP 即 Active Server Page, 是 一 个 Web 服务 器 端的 开发 技术 ,利用 它 可 以 
编写 和 执行 动态 的 .互动 的 Web 应 用 程序 ,ASP 采用 VBScript 和 JavaScript 作为 脚本 语 
言 。 但 由 于 它 是 基于 微软 的 IIS 服务 器 的 ,性 能 受到 一 定 的 影响 ,安全 性 也 较 差 , 目 前 已 经 
逐渐 不 受 青 睐 。 

(2) JSP。JSP 即 Java Server Page, 它 是 由 Sun 公司 于 1999 年 6 月 推出 的 新 技术 ,是 基 
于 Java Servlet 以 及 整个 Java 体系 的 Web 开发 技术 。 由 于 JSP 采 用 Java 作为 脚本 语言 , 具 
有 极 强 的 扩展 性 、 良 好 的 收缩 性 ,以 及 与 平台 无 关 的 开发 特性 ,被 认为 是 极 具 发 展 潜力 的 动 
态 网 站 技术 。 

(3) PHP。PHP 即 PHP:Hypertext Preprocessor( 超 文本 预 处 理 器 ) ,是 一 种 跨 平 台 的 
服务 器 端的 脚本 语言 。 它 大 量 地 借用 C、Java 和 Perl 语言 的 语法 ,并 耦合 PHP 自己 的 特 
性 ,使 Web 开发 者 能 够 快速 地 写 出 动态 生成 页 面 。 它 支持 目前 绝 大 多 数 数据 库 。PHP 适 
合 于 开发 中 ,小 规模 企业 级 网 站 ,以 及 微 信 后 台 开 发 ,因此 它 正 逐步 成 为 一 种 热门 的 动态 网 
站 开发 语言 。 

(4) ASP. NET。 在 ASP 的 基础 上 ,微软 公司 推出 了 ASP. NET ,但 它 不 是 ASP 的 简单 
升级 , 它 不 仅 吸 收 了 ASP 技术 的 优点 并 改正 了 ASP 中 的 某 些 缺憾 ,更 重要 的 是 , 它 借鉴 了 
Java、Visual Basic 语言 的 开发 优势 .从 而 成 为 Microsoft 推出 的 新 一 代 Active Server Page。 
ASP. NET 是 微软 发 展 的 新 的 体系 结构 . NET 的 一 部 分 , 它 主要 适合 于 开发 大 型 企业 级 、 商 
务 级 的 网 站 。 

1.1.3 PHP 语言 的 特点 

PHP 作为 一 种 服务 器 端的 脚本 语言 , 它 主要 有 以 下 6 个 特点 。 

(1) 开放 源 代码 


PHP 属于 自由 软件 ,是 完全 免费 的 ,用 户 可 以 从 PHP 官方 网 站 (http://www. php. net) 自 
由 下 载 ,而 且 可 以 不 受 限 制 地 获得 源码 ,甚至 可 以 从 中 加 进 自己 需要 的 特色 。 








第 1 章 “PHP 开 发 环境 (3 

(2) 基于 Web 服务 器 

常见 的 Web 服务 器 有 IIS: 运行 ASP、ASP. net 脚本 ,默认 占用 TCP 80 端口 ; 
@Tomcat: 运行 JSP 脚本 ; @Apache: 运行 PHP 脚本 ,默认 占用 TCP 80 端口 。 

PHP 运行 在 Apache 服务 器 ,PHP 的 运行 速度 只 与 服务 器 的 速度 有 关 。 当 服务 器 的 一 
个 PHP 页 面 第 一 次 被 访问 时 ,服务 器 就 对 它 进行 编译 ,只 要 服务 器 未 关闭 , 则 往 后 不 管 哪 
个 客户 机 访问 该 页 面 时 ,不 必 再 编译 。 因 此 ,PHP 有 高 效 的 运行 速度 。 

(3) 数据 库 支 持 

PHP 能 够 支持 目前 绝 大 多 数 的 数据 库 , 如 DB2、MySQL、Microsoft SQL Server、 
Sybase .Oracle PostgreSQL 等 ,并 完全 支持 ODBC, 即 Open DataBase Connectivity( 开 放 数 
据 库 连接 ), 因 此 可 以 连接 任何 支持 该 标准 的 数据 库 。 其 中 ,PHP 与 MySQL 是 绝 佳 的 
组 合 。 

(4) 跨 平台 

PHP 可 以 在 目前 所 有 主流 的 操作 系统 上 运行 ,包括 Linux、UNIX 的 各 种 变种 ， 
Microsoft Windows、Mac OS X、RISC OS 等 ,下 是 由 于 这 个 特点 ,使 UNIX/Linux 操作 系统 
上 有 了 一 种 与 ASP 相 媲美 的 开发 语言 。 

(5) 易于 学 习 

PHP 的 语法 接近 C Java 和 Perl, 学 习 起 来 非常 简单 ,而 且 拥 有 很 多 学 习 资 料 。PHP 
还 提供 数量 巨大 的 系统 函数 集 , 用 户 只 要 调用 一 个 函数 就 可 以 完成 很 复杂 的 功能 , 编 
程 时 十 分 方便 。 因 此 ,用 户 只 需要 很 少 的 PHP 编程 知识 就 能 够 建立 一 个 交互 的 Web 

(6) 安全 性 

由 于 PHP 本 身 的 代码 开放 ,所 以 它 的 代码 由 许多 工程 师 进 行 了 检测 ,同时 它 与 Apache 
编译 在 一 起 的 方式 也 让 它 具 有 灵活 的 安全 设置 ,PHP 具有 了 公认 的 安全 性 能 。 


1.2 集成 开发 环境 配置 


进行 PHP 开发 之 前 ,必须 先 建立 开发 环境 。 分 立 组 件 开发 环境 虽然 提供 了 全 方位 的 
手动 配置 灵活 性 ,但 是 其 安装 及 配置 方法 比较 复杂 。 对 于 一 般 的 应 用 来 说 ,安装 一 个 集成 开 
发 环境 就 方便 多 了 。 目 前 来 说 ,集成 开发 环境 主要 有 WampServer 及 PHPnow 两 种 流行 软 
件 。 本 书 将 以 WampServer 为 开发 环境 ,但 是 它 的 原理 也 适用 于 其 他 开发 环境 。 


1.2.1 WampServer 简介 


WampServer 是 一 款 由 法 国人 开发 的 Apache 服务 器 .PHP 解释 器 以 及 MySQL 数据 
库 的 整合 软件 包 , 省 去 了 开发 人 员 将 时 间 花 费 在 烦琐 的 配置 环境 过 程 ,从 而 腾 出 更 多 精力 去 
做 应 用 开发 。WAMP 是 Windows 十 Apache 十 MySQL 十 PHP 的 简称 。WampServer 拥有 
简单 的 图 形 和 菜单 安装 和 配置 环境 ,在 WampServer 中 对 PHP 扩展 .Apache 模块 开启 / 关 
闭 都 很 方便 搞定 ,再 也 不 用 亲自 去 修改 配置 文件 了 。 这 个 软件 是 完全 免费 的 ,可 以 在 其 官方 
网 站 下 载 到 最 新 的 版 本 。 











1.2.2 WampServer 安装 


(1) 运行 WampServer 安装 包 , 如 图 1-1 所 示 , 单 击 Next 按钮 。 













人 Welcome to the WampServer 2 


\ yp Setup Wizard 
WampServer This wl instal WampServer 2,2 on your computer, 
Lis recommended that you close all other applications before 
Powered by erie. 
Alter Way Clkck Next to continue, or Cancel to exit Setup. 
The French 
Open Source 
Service Provider 
http:/iwww.alterway.ir 


人 





图 1-1 安装 时 的 欢迎 界面 
(2) 在 授权 界面 中 单 击 I accept the agreement, 如 图 1-2 所 示 , 单 击 Next 按钮 。 





1-2 要求 接受 授权 


(3) 在 如 图 1-3 所 示 的 界面 中 选择 安装 路 径 , 也 可 以 按照 默认 安装 到 c:\wamp 文件 夹 
中 , 单 击 Next 按钮 。 

(4) 现在 可 以 选择 安装 之 后 ,是 否 要 创建 一 个 快捷 启动 图 标 ,或 者 创建 一 个 桌面 快捷 方 
式 图 标 , 如 图 1-4 所 示 。 按 照 默认 ,直接 单 击 Next 按钮 即 可 。 

(5) 在 如 图 1-5 所 示 的 界面 中 ,显示 本 次 安装 的 相关 信息 ,如 果 确 认 无 误 , 则 单 击 Install 
按钮 开启 安装 进程 。 


第 1 章 “PHP 开 发 环境 〔 5 ) 





Select Destination Location 
Where should WampServer 2 be instaled? 








Ready to Install 
Setup is now ready to begin instaling Wamp5erver 2 on your computer 





图 1-5 安装 之 前 确认 安装 参数 





(6) 安装 过 程 中 可 能 弹出 提示 ,要 用 户 选择 默认 浏览 器 ,如 图 1-6 所 示 , 直接 单 击 


“打开 ”按钮 即 可 。 








图 1-6 选择 默认 浏览 器 


(7) 安装 过 程 可 能 出 现 如 图 1-7 所 示 的 错误 ,这 时 需要 到 网 上 搜索 MSVCR100. dll 这 
个 文件 ,并 把 它 存储 到 C:\windows\system32 文件 夹 下 。 


httpd.exe - 无 法 找到 组 件 


Xx 





图 1-7 安装 过 程 可 能 出 现 的 错误 


(8) 在 如 图 1-8 所 示 的 界面 指定 PHP 邮件 服务 器 参数 ,这 里 保持 默认 值 , 单 击 Next 
按钮 。 








1-8 指定 PHP 邮件 服务 器 参数 
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(9) 出 现 如 图 1-9 所 示 界 面 , 单 击 Finish 按钮 结束 安装 。WampServer 会 自动 启动 ,在 
任务 栏 右 下 角 出 现 一 个 画图 标 。 















Completing the WampServer 2 
岂 ) Setup Wizard 
WampServer has finished instaling Wamp5erver 2 i 
和 Te mie ey elec py ee 
icons. 
Powered by 
Alter Way Clhck Finish to eat Setup. 
The French i 
Open Source 区 Weamp5erver2now 
Service Provider 
http:/www.alterway.ir 


图 1-9 安装 成 功 


(10) 单 击 任务 栏 右 下 角 的 辆 | 图标 ,选择 Apache, 然 后 选中 Service, 如 图 1-10 所 示 , 检 
查 Apache 服务 器 是 否 已 启动 。 






国 Localhost 
NE phpilysdnin 
wr directory 













BB Alias directories »|® Stop Service 
国 httpd. conf 多 Restart Service 

转 Apache error log 
国 Apache access log 









» Test Port 80 
Install Service 
冒 Renove Service 


Put Online 
图 1-10 检查 Apache 服务 器 是 否 已 启动 


如 果 Apache 服务 器 不 能 正常 启动 ,一 个 主要 原因 是 Apache 程序 默认 占用 80 端口 ,而 
JIS 服务 器 也 占用 80 端口 。 只 要 把 IIS 的 80 端口 改 为 其 他 
端口 (如 改 为 8080) 或 停止 IIS. 然 后 重新 启动 WampServer 
即 可 。 


1.2.3 WampServer 配置 


WampServer 安装 成 功 之 后 , 仍 需要 对 其 进行 设置 ,以 局 全 席 六 
符合 用 户 的 使 用 习惯 和 需求 。 
(1) 设置 为 中 文 界面 。 | 
右 击 任务 栏 右 下 角 的 国 图 标 ,选择 Language, 然 后 选 
中 chinese, 如 图 1-11 所 示 。 1-11 选择 语言 为 中 文 
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(2) 重新 设置 PHP 站 点 的 位 置 。 

PHP 站 点 的 默认 位 置 为 C:/wamp/www/ ,该 位 置 恰好 是 软件 安装 目录 。 一 般 来 说 ,上 
户 的 工作 目录 不 要 放 在 软件 安装 目录 下 ,因此 有 必要 修改 一 下 。 可 通过 修改 Apache/ 
httpd. conf 文件 的 内 容 , 重 新 设置 PHP 站 点 的 位 置 。 

【 例 1-1】 将 PHP 站 点 的 位 置 修改 为 E:/php/www/。 

操作 步骤 如 下 。 

@ 停止 IIS 服务 器 。 

@ 启动 WampServer, 单 击 任务 栏 中 的 败 图标, 选择 Apache, 然 后 单 击 httpd. conf 命 
今 ,如 图 1-12 所 示 , 打 开 httpd. conf 文件 。 


二 | 




























Localhost 
phpltyAdnin 
wwv 目录 (WY) 











国 hpache 错误 日 志 (P) 
国 Apache 访问 日 志 (C) 









启动 所 有 服务 (9) 
停止 所 有 服务 (x) 
重新 启动 所 有 服务 (Y) 


切换 到 在 线 状 态 (7) 





图 1-12 选择 httpd. conf 命令 


@ 修改 httpd. conf 中 的 文档 根 目录 : 将 DocumentRoot 后 面 的 "C:/wamp/www/" 修 
改 为 "E:/php/www/"。 注 意 目录 中 不 能 出 现 汉 字 。 

@ 修改 httpd. conf 中 的 权限 目录 ,权限 目录 必须 与 文档 根 目 录 相同 : 将 二 Directory 
"C;/wamp/www/" 二 修改 为 : 二 Directory "E:/php/www/" 二 ,重新 保存 httpd, conf 文件 。 

@ 重新 启动 WampServer。 

(3) 设置 Apache 监听 端口 :也 就 是 网 站 的 访问 端口 。 

WampServer 默认 安装 之 后 的 Apache 监听 端口 是 80, 但 是 如 果 你 的 计算 机 中 已 安装 
有 IS( 默 认 端口 也 是 80) ,或 者 其 他 服务 器 占用 了 80 端口 ,为 避免 冲突 ,可 修改 Apache 端 
口号 ,也 可 修改 其 他 端口 号 。 

如 果 要 修改 Apache 端口 号 , 则 方法 如 下 : 打开 WampServer 主 菜单 ( 见 图 1-12) ,选择 
Apache, 然 后 单 击 httpd. conf , 则 会 用 记事 本 打开 该 文件 ,分 别 搜索 到 如 下 两 行 (注意 此 两 行 
并 不 在 同一 个 地 方 ) ,把 最 后 的 80 改 为 你 想 要 的 新 的 端口 号 (例如 8080) 即 可 。 


Listen 80 
ServerName localhost:80 


1.2.4 PHP 编辑 器 


PHP 程序 语言 实际 上 就 是 一 些 文本 字符 (英文 ,数字 .中文 等 ) ,因此 ,本 质 上 可 以 用 任 
何 能 够 编辑 文本 的 软件 来 编辑 PHP 代码。 但 是 如 果 有 一 个 专门 编辑 PHP 的 编辑 器 ,将 会 
大 大 方便 PHP 开发 。 
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目前 有 不 少 可 用 于 编辑 PHP 代码 的 PHP 编辑 器 ,最 简单 的 是 Windows 自 带 的 记事 
本 。 除 此 之 外 ,Dreamweaver 是 专门 用 于 设计 、 制 作 网 页 的 “利器 ”, 它 内 置 了 ASP、PHP 等 
动态 网 页 语言 ,所 以 也 可 以 用 来 编辑 PHP 代码 。 另 外 还 有 Eclipse for PHP, 它 也 是 非常 不 
错 的 PHP 开发 集成 环境 。 本 书 采 用 Dreamweaver CS4 作为 PHP 网 页 编辑 器 ,以 实现 快速 
的 所 见 即 所 得 效果 。 








1.3 典型 PHP 程序 实例 


为 了 快速 了 解 PHP 可 以 干什么 .PHP 代码 大 概 长 什么 样子 ,本 节 先 介绍 如 何在 
Dreamweaver 中 创建 PHP 站 点 ,然后 举 几 个 典型 PHP 程序 实例 。 


1.3.1 在 Dreamweaver 中 创建 PHP 站 点 


【 例 1-2】 假设 PHP 站 点 的 位 置 为 : E:/php/www/，, 现 要 在 EE:/php/www/ 目 录 下 创 
建站 点 MyPHP。 

操作 步 又 如 下 。 

(1) 启动 Dreamweaver CS4。 

(2) 选择 “站 点 ”>“ 管 理 站 点 ”, 在 管理 站 点 对 话 框 中 单 击 “ 新 建 " 按 钮 。 

(3) 在 弹出 的 对 话 框 中 ,选择 “高 级 "选项 卡 , 然 后 选择 “本 地 信息 ”, 填 写 “ 站 点 名 称 ” 为 
MyPHP;“ 本 地 根 文件 夹 ” 为 E:\php\www\MyPHP\;“ 上 默认 图 像 文件 夹 ” 可 填 也 可 不 填 ; 
“HTTP 地 址 ”为 http://localhost/ MyPHP/, 如 图 1-13 所 示 。 





MyPHP 的 站 点 定义 为 








站 点 名 称 加: |W 
本 地 根 文件 夹 E); [E; \php\wwwWiyPHP\ 
默认 图 重文 件 夹 四 - [ > 


链接 相对 于 : @@ 文档 四 ) ”人 〇 站 点 根 目录 G) 








JITP 地 址 0 : |http://localhost/MyPHP/ 


此 地 址 用 于 站 点 相对 链接 ,以 及 殿 链 接 检查 
器 用 于 检测 引用 您 的 站 点 的 UTP 链接 


区 分 大 小 写 的 链接 : 口 ] 使 用 区 分 大 小 写 的 链接 检查 ) 
组 存 : 回 启 用 缓存 双 ) 


Me 
































图 1-13 填写 “本 地 信息 ” 
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(4) 选择 “测试 服务 器 ”, 填写 “服务 器 模型 "为 PHP MySQL;“ 访 问 " 选 择 “ 本 地 /网 
络 ”; “测试 服务 器 文件 ”选择 默认 ;“URL 前 缀 ”为 http://localhost/MyPHP/, 如 图 1-14 
所 示 。 


了 7PHP 的 站 点 定义 为 








WL 前 妖 : [http://1ocalhost/WyPHP/ 
务 器 上 站 点 根 文件 
Ei 


























图 1-14 填写 “测试 服务 器 ” 


(5) 单 击 “ 确 定 ” 按 钮 ,结束 站 点 的 创建 。 
注意 ; 本 书 的 所 有 网 页 都 在 MyPHP 站 点 中 创建 ,以 后 不 再 珊 述 。 


1.3.2 最 简单 的 PHP 程序 


【 例 1-3】〗 在 MyPHP 站 点 中 新 建 一 个 网 页 EX1-1. php, 用 于 输出 Hello，World! 。 
操作 步骤 如 下 。 
(1) 在 Dreamweaver 中 打开 站 点 MyPHP, 在 MyPHP 目录 下 创建 一 个 网 页 EX1-1. php。 
(2) 编写 EX1-1. php 的 代码 如 下 : 
<! DOCTYPE html > 
<html> 
<body> 
<?php 
echo 'Hello, World! '; 
?> 
</body > 
</html > 


(3) 在 Dreamweaver 中 按 F12 键 , 出 现 IE 浏览 器 (或 计算 机 上 安装 的 浏览 器 ) ,可 以 看 
到 运行 效果 。 
说 明 : 网 页 的 第 一 行 二 !IDOCTYPE html 放 ,表示 该 网 页 为 HTML5 页 面 。 其 中 ， 
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<<html>> <<body>>、<</body>>`.<</html> 称 为 HTML 标记 ;“<? php” 与 “? 之 ” 则 是 
PHP 脚本 开始 和 结束 的 标记 ,PHP 语句 就 写 在 这 对 标记 之 间 。 同 一 个 文件 中 可 以 有 多 对 
PHP 标记 ,但 互相 之 间 不 能 能 套 。 

代码 中 的 echo 语句 ,用 于 输出 一 个 或 多 个 表达 式 的 值 ,语法 是 : 

echo 表达 式 表 ; 

PHP 语言 是 大 小 写 敏感 的 语言 ,其 语法 类 似 于 C 语言 。 

1.3.3 同一 页 面 上 的 PHP 交互 


PHP 程序 主要 作用 是 可 以 和 用 户 交互 ,也 就 是 说 ,可 以 在 网 页 上 获取 用 户 的 输入 数据 ， 
通过 后 台 处 理 之 后 ,再 把 处 理 结果 呈现 给 用 户 。 既 可 以 将 数据 输入 和 输出 结果 放 在 同一 个 
网 页 中 ,也 可 以 将 数据 输入 和 输出 结果 分 别 放 在 不 同 的 网 页 中 。 

【 例 1-4】 创建 一 个 网 页 EX1-2. php, 主 要 功能 是 : 当 用 户 输入 一 个 边 长 值 ,并 单 击 “ 提 
交 ” 按 钮 后 ,就 能 在 同一 页 面 显示 正方 形 的 面积 。 

(1) 新 建 EX1-2. php 网 页 ,然后 在 Dreamweaver 的 设计 视图 创建 如 图 1-15 所 示 的 
页 面 。 


请 给 入 一 个 正方 形 的 边 长 下] 
图 1-15 设计 视图 
(2) 切换 到 代码 视图 ,输入 PHP 脚本 ,使 整个 页 面 的 代码 如 下 : 


<! DOCTYPE html > 
<html> 
<body> 
<form id = "forml" name = "forml" method= "post" action=""> 
请 输入 一 个 正方 形 的 边 长 
< input type = "text" name = "Rad" id = "Rad"” /> 
< input type = "submit" name = "send" id = "send" value = "提交 ”/> 
</form> 
<?php 
if(isset( $ _POST[ 'send'])) 
{ 





$ Rad = $_POST[ 'Rad']; 
$area = $Rad * $ Rad; 
echo ' 正 方形 的 面积 是 '. $ area; 
} 
?> 
</body> 
</html > 


(3) 运行 网 页 ,在 文本 框 中 输入 20, 单 击 “ 提 交 ” 按 钮 ,可 看 到 下 面 显示 一 行 信息 ,如 
图 1-16 所 示 。 


请 输入 一 个 正方 形 的 边 长 
正方 形 的 面积 是 400 


图 1-16 同一 页 面 交 互 程序 运行 结果 


程序 解释 : 

(1) $_POST[" 表 单 变 量 "]: 取得 从 客户 端 传 递 过 来 的 表单 变量 的 value 值 , 它 是 
PHP 的 预定 义 变量 。 

(2) isset( 变 量 名 ): 用 于 判断 变量 名 是 否 存在 , 若 存在 则 返回 true。 

(3) $ Rad 一 $ _POST[L 'Rad ']: 前 面 $ Rad 为 PHP 变量 ,必须 以 $ 开 头 ; 后 面 Rad 
为 表单 变量 ,它们 可 以 同名 ,也 可 以 不 同名 。 

(4) 字符 串 . 变量 名 : 先 统一 为 字符 串 , 再 连接 成 一 个 新 串 。 其 中 的 . 称 为 连接 号 。 

当 用 户 初次 浏览 该 网 页 时 ,还 没有 发 送 send 的 数据 ,因此 不 会 看 到 下 面 一 行 字 。 当 用 
户 输入 数据 20 并 单 击 “ 提 交 ” 按 钮 之 后 ,表单 变量 (包括 Rad、send) 的 value 值 被 发 送 到 服务 
器 ,因此 ,在 if 中 判断 得 到 send 数据 有 效 ,进入 语句 体 中 ,取出 size 数据 , 自 乘 ,得 到 面积 , 然 
后 用 echo 语句 进行 输出 。 


1.3.4 不 同 页 面 上 的 PHP 交互 


把 1. 3. 3 小 节 中 的 代码 一 分 为 二 ,把 PHP 代码 部 分 写 在 另 一 个 PHP 文件 中 , 则 可 以 实 
现 不 同 页 面 上 的 PHP 交互 ,方法 如 下 。 

(1) 新 建 EX1-3a. htm 网 页 ,然后 在 设计 视图 创建 如 图 1-15 所 示 的 页 面 ,其 HTML 代 
码 如 下 ,注意 在 action 中 填 人 了 新 文件 名 。 


<! DOCTYPE html > 
<html> 
<body> 
< form id = "forml" name = "forml" method= "post" action= "EX1 — 3b. php"> 
请 输入 一 个 正方 形 的 边 长 
< input type = "text" name = "Rad" id = "Rad" /> 
< input type = "submit" name = "send” id = "send" value = "提交 " /> 
</form> 
</body> 
</html > 


(2) 新 建 EX1-3b. php 网 页 ,在 其 中 编写 PHP 脚本 如 下 : 


<?php 
if(isset( $ _POST[ 'send'])) 
{ 
$ Rad = $_POST[ 'Rad']; 
$area = $Rad * $ Rad; 
echo ' 正 方形 的 面积 是 '. $ area; 
} 


?> 


(3) 运行 EX1-3a. htm, 输 入 20, 单 击 “ 提 交 ” 按 钮 ,就 会 自动 执行 EX1-3b. php 网 页 , 显 
示 执 行 结果 。 
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1.4 项 目 实 训 


实 训 1 在 Dreamweaver 中 创建 PHP 站 点 


实 训 目 的 

(1) 掌握 在 WampServer 中 修改 PHP 站 点 位 置 的 方法 。 

(2) 掌握 在 Dreamweaver 中 创建 PHP 站 点 的 方法 。 

(3) 了 解 站 点 与 网 页 的 关系 。 

实 训 要 求 

(1) 在 硬盘 上 建立 一 个 文件 夹 E:Ntest。 

(2) 在 WampServer 中 把 将 PHP 站 点 的 位 置 修 改 为 E:/test/。 

(3) 在 Dreamweaver 中 ,创建 一 个 新 的 PHP 站 点 ,站 点 名 称 为 sx1, 站 点 文件 夹 为 E:\ 


test\sxl。 
实 训 2 创建 一 个 PHP 网 页 


实 训 目 的 

(1) 掌握 创建 PHP 网 页 的 方法 。 

(2) 了 解 PHP 网 页 的 组 成 和 运行 过 程 。 

实 训 要 求 

(1) 在 sxl 站 点 中 ,利用 Dreamweaver 创建 一 个 页 面 sxl-1. php, 设 计 界 面 如 图 1-17 
所 示 。 


(2) 编写 PHP 代码 ,功能 是 : 当 用 户 输入 所 有 信息 ,并 单 击 “确认 ”按钮 之 后 ,得 到 如 
图 1-18 所 示 的 界面 。 





已 无 标题 文档 - Windows Tale|EE4 
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图 1-17 设计 界面 图 1-18 运行 界面 
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思考 与 练习 








一 、 填空 题 

1. 目前 比较 关注 的 动态 网 页 设计 技术 有 、 、 等 。 

2. 常见 的 Web 服务 器 有 

3. PHP 中 的 语句 用 于 输出 一 个 或 多 个 表达 式 的 值 ， 函数 用 于 判断 
一 个 变量 是 否 存 在 。 

二 、 简 答 题 


1. 讲述 静态 网 页 与 动态 网 页 的 区 别 和 联系 。 
2. PHP 语言 有 哪些 特点 ? 


PHP 的 语法 分 为 面向 过 程 部 分 与 面向 对 象 部 分 ,其 中 ,面向 过 程 部 分 的 语法 类 似 于 
C 语言 的 语法 ,面向 对 象 部 分 的 语法 类 似 于 C++ 或 Java 的 语法 。 读 者 在 学 习 PHP 语法 时 ， 
应 多 与 C 语言 或 Java 进行 对 比 学 习 。 本 章 仅 介绍 PHP 面向 过 程 部 分 的 语法 。 


外 ooee 


。 了解 PHP 文件 的 组 成 。 

。 掌握 PHP 语言 的 数据 类 型 。 

。 掌握 PHP 语言 的 变量 类 型 。 

。 掌握 PHP 语言 的 流程 控制 语句 。 
。 掌握 PHP 函数 的 定义 和 调用 。 


2.1 PHP 入 门 


1. PHP 文件 的 组 成 

PHP 文件 是 一 种 文本 文件 , 它 既 可 以 和 HTML 代码 混在 一 起 ,也 可 以 单独 编写 纯 
PHP 代码 。 具 体 来 说 ,一 个 PHP 文件 由 以 下 几 个 部 分 组 成 。 

(1) HTML 标记 : 一 般 作为 页 面 中 的 布局 ,或 者 是 页 面 中 的 固定 不 变 的 部 分 。 

(2) JavaScript 脚本 : 由 一 script language 王 "JavaScript" 二 与 一 /script 二 括 住 。 

(3) PHP 脚本 : 以 “<? php” 开 始 ,“? 二 ”结束 。 

除 使 用 上 述 标 记 外 ,PHP 脚本 还 允许 使 用 其 他 样式 的 标记 ,但 本 书 只 使 用 上 述 标记 ,对 
于 其 他 标记 不 予 介绍 。 

其 中 ,HTML 标记 、JavaScript 脚本 在 客户 端 运行 ; PHP 脚本 在 服务 器 端 运行 。 如 果 
一 个 网 页 含有 PHP 脚本 ,那么 该 网 页 为 动态 网 页 ,扩展 名 必须 为 . php。 








2. PHP 脚本 中 的 注释 
类 似 于 C 语言 ,可 以 有 两 种 注释 风格 。 
(1) 单行 注释 : 从 // 开 始 直到 行 末 , 均 属于 注释 部 分 。 例 如 : 


<?php 
echo "Hello"; // 输 出 Hello 
echo "World"; 

?> 


(2) 多 行 注释 : 从 /* 开始 到 * /结束 ,不 管 有 多 少 行 , 均 属于 注释 部 分 。 例 如 : 


<?php 
/* 先 输出 Hello, 
再 输出 World. 
*/ 
echo "Hello"; 
echo "World"; 


?> 
3. 输出 语句 
PHP 有 如 下 两 种 输出 语句 。 


(1) print 表达 式 

(2) echo 表达 式 表 

表达 式 中 可 以 出 现 . 号 或 十 号 ,常用 的 几 种 形式 如 下 。 

(1) 字符 串 . 字符 串 

(2) 字符 串 . 变 量 名 

(3) 字符 串 十 字符 串 

(4) 字符 串 十 数值 

注意 : 在 (1)、(2) 形 式 中 , 先 统一 为 字符 串 , 再 运算 。 在 (3)、(4) 形 式 中 , 先 统一 为 数值 ， 
再 运算 。 不 能 出 现 “ 字 符 串 .数值 ”的 形式 ,因为 此 处 的 . 号 出 现 二 义 性 。 


例如 : 

<?php 
$a=123; 
echo "123". "abc". "<br >"; // 输 出 : 123abc 
echo $a."abc"."<br>"; // 输 出 : 123abc 
echo "123" + "abc". "<br >"; // 输 出 : 123 
echo 123 + "abc". "<br >"; // 输 出 : 123 

?> 

4. 输出 每 个 表达 式 的 类 型 和 值 

格式 : 

var_dump( 表达 式 , …, 表达 式 ) 

例如 : 

<?php 


$x= true; 
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var_dump(2+ 3, $ x); // 输 出 : int 5,boolean true 
?> 


2.2 PHP 数据 类 型 


PHP 支持 8 种 数据 类 型 : int( 整 型 )、float( 浮 点 型 )、string (字符 串 型 )、boolean (布尔 
型 ) ,array( 数 组 ) .object( 对 象 ) NULL( 空 ) 和 resource( 资 源 )。 基 本 数据 类 型 有 4 种 ,分 别 
是 整 型 、 浮 点 型 .字符 串 型 和 布尔 型 ,有 常量 和 变量 之 分 。 


2.2.1 整 型 

整 型 的 值 称 为 整 型 常量 ,简称 整数 ,可 以 用 十 进 制 数 . 十 六 进 制 数 .八进制 数 或 二 进 制 数 
(PHP 5. 4.0) 表 示 。 十 六 进 制 数 前 面 必 须 加 0x, 如 0x12; 八进制 数 前 面 必须 加 0, 如 012; 
二 进 制 数 前 面 必须 加 0b, 如 0b1000。 

2,2.2 泽 点 型 


浮 点 型 的 值 称 为 浮 点 型 常量 ,有 小 数 形式 和 指数 形式 两 种 表示 法 。 小 数 形式 如 0. 0528， 
写成 指数 形式 为 5. 28e 一 2。 在 指数 形式 中 ,e 的 前 后 必须 有 数字 , 且 e 的 后 面 必须 为 整数 。 


2.2.3 字符 串 型 
在 PHP 中 ,以 单 引号 或 双 引号 括 住 的 一 个 或 多 个 字符 称 为 字符 串 常量 。 例 如 , 'school '、 


"school"、'\n '。 

(1) 单 引 号 

用 两 个 单 引 号 (可 以 把 一 个 字符 串 括 起 来 ,但 要 注意 的 是 ,如 果 这 个 字符 串 本 身 包含 
单 引 号 ( ), 则 必须 写成 (\"); 如 果 字 符 串 中 本 身 包含 (\ 7 , 则 必须 改写 成 (\\\"); 如 果 字符 
串 末尾 刚好 是 一 个 反 斜 枉 (\) , 则 必须 改写 成 双 反 和 斜 枉 (\\)。 例 如 : 


<?php 
echo ' 这 个 符号 \' 是 单 引号 '; // 输 出 : 这 个 符号 ' 是 单 引号 
echo ' 这 个 符号 \\\ ' 是 反 斜 杠 加 单 引号 '; // 输 出 : 这 个 符号 \' 是 反 斜 杠 加 单 引号 
echo ' 这 个 字符 串 以 反 斜 杠 结尾 \\ // 输 出 : 这 个 字符 串 以 反 斜 杠 结尾 \ 
echo ' 这 个 字符 串 有 \n, 但 不 转 义 // 输 出 : 这 个 字符 串 有 \n, 但 不 转 义 
?> 
(2) 双 引 号 


用 两 个 双 引号 (") 可 以 把 一 个 字符 串 括 起 来 ,但 要 注意 的 是 ,这 种 字符 串 有 一 些 特殊 转 
义 序列 ,如 表 2-1 所 示 。 

使 用 单 引 号 和 双 引 号 的 主要 区 别 是 : 单 引 号 内 出 现 的 变量 名 不 会 被 变量 内 容 代替 ,但 
双 引 号 内 出 现 的 变量 名 会 被 变量 内 容 所 代替 。 例 如 : 





<?php 
$str= "加 油 "; 
echo ' 中 国 $ str! '; // 输 出 : 中 国 $ str! 
echo "中 国 $ str!"; // 输 出 : 中 国 加 油 ! 

















?> 
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表 2-1 特殊 字符 转 义 序列 表 












































序 列 显示 效果 或 含义 
WW 反 斜 杠 (\) 
\ 双 引 号 (") 
\n 网 页 源 文件 中 换行 ,但 显示 效果 为 空格 ( 若 无 前 后 分 隔 时 ) 
\r 同上 
\t 网 页 源 文件 中 水 平 制 表 符 ,但 显示 效果 为 空格 ( 若 无 前 后 分 隔 时 ) 
\v 垂直 制 表 符 
\e Esc 
\f 换 页 
\$ 美元 符号 ($ ) 
\[0-7]{1,3} 此 正则 表达 式 匹配 一 个 用 八进制 数 表示 的 字符 
\x[0-9A-Fa-{]{1,2} 此 正则 表达 式 匹 配 一 个 用 十 六 进 制 数 表示 的 字符 





2.2.4 布尔 型 

布尔 型 的 取 值 只 有 两 种 : TRUE( 真 ) 和 FALSE( 假 ) ,也 可 以 用 小 写 的 true 和 false。 布 
尔 值 在 显示 时 ,TRUE 显示 为 1,FALSE 显示 为 空 。 

2.2.5 数组 


数组 是 一 组 * 键 名 / 值 ”,“ 键 名 ”在 数组 中 是 唯一 的 ,可 以 是 整数 或 字符 串 , 键 名 省 略 时 默 
认为 从 0 开始 的 连续 整数 。“ 值 "是 由 相应 的 键 名 映射 的 结果 , 值 可 以 不 唯一 。 例 如 : 


<?php 
$arrl =array(2, 4,6,8); // 不 指定 键 名 , 直接 赋值 
$arr2=array( 'name’ =>"Li", 'age'’=>20, 'married'=> false); // 指 定 键 名 
echo $arrl[3]; // 输 出 : 8 
echo $ arr2[ 'name']; // 输 出 : Li 

?> 

2.2.6 对 象 


“对 象 " 这 个 概念 是 面向 对 象 编程 里 面 的 概念 ,有 关内 容 请 参见 第 4 章 。 
2.2.7 NULL 类 型 


NULL 类 型 只 有 一 种 取 值 ,就 是 NULL( 不 区 分 大 小 写 ) 。 一 个 变量 在 下 列 情况 下 被 认 
为 是 NULL。 

(1) 被 直接 赋值 为 NULL。 

(2) 尚未 被 赋值 。 

(3) 被 unset() 函数 销毁 。 

例如 : 


<?php 
$ varl = NULL; 
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$ var2; 

$ var3= "school"; 

unset( $ var3); 

var_dump( $ varl); 

var_dump( $ var2); 

var_dump( $ var3); 
We 


2.2.8 资源 类 型 


// 直 接 输出 NULL 
// 先 显示 未 定义 ,再 输出 NULL 
// 先 显示 未 定义 ,再 输出 NULL 


资源 resource 是 一 种 特殊 变量 , 它 相 当 于 一 个 外 部 资源 的 引用 ,例如 一 个 “数据 库 连 


接 ” 就 是 一 个 资源 ,请 参见 7. 1. 1 小 节 。 


2.3 PHP 变量 


变量 是 程序 运行 过 程 中 ,各 种 数据 所 存储 的 载体 。 程 序 根据 变量 的 名 称 而 找到 对 应 的 


数据 。 
2.3.1 自 定义 变量 


以 $ 开 头 ,再 加 上 一 个 合法 的 字符 串 , 就 成 为 自 定 义 变量 名 。 所 谓 合法 ,是 指 以 字母 或 
下 画 线 开头 ,后 面 跟着 任意 数量 的 字母 ,数字 或 下 画 线 。 


1. 变量 的 类 型 


由 于 PHP 变量 在 使 用 之 前 并 不 需要 像 C 语言 那样 事先 定义 变量 类 型 ,因此 ,变量 一 般 
是 通过 初始 化 来 定义 的 ,初始 化 时 给 变量 赋 一 个 值 。PHP 变量 的 类 型 由 所 赋值 的 类 型 





决定 。 
例如 ， 


<?php 
$a=100; 
$b=3.14; 
$c= "school"; 
$d= true; 

?> 


2. 变量 赋值 的 方式 


//$ a 为 整 型 变量 

//$b 为 浮 点 型 变量 
//$ c 为 字符 串 变量 
//$ d 为 布尔 型 变量 


(1) 值 赋值 : 将 一 个 变量 的 值 赋 给 另 一 个 变量 ,例如 , $ a== $b。 
(2) 引用 赋值 : 将 一 个 变量 的 地 址 赋 给 另 一 个 变量 ,例如 ,$a 二 & $b, 将 $b 的 地 址 赋 
给 $a, 让 $a、$b 共 同 占 用 一 个 存储 单元 。 下 面 是 引用 赋值 的 示例 。 


<?php 
$var = "hello"; 
$bar= &$ var; 
echo $ bar; 
$ bar = "world"; 
echo $ var; 


// 输 出 : hello 


// 输 出 : world 


?> 


3. 变量 的 作用 域 

按 作用 域 分 ,变量 可 分 为 局 部 变量 和 全 局 变量 。 

(1) 局 部 变量 

在 主 程序 中 或 函数 内 部 定义 的 变量 称 为 局 部 变量 。 在 主 程序 中 定义 的 局 部 变量 ,其 作 
用 域 局 限于 主 程序 ,不 能 在 函数 内 部 使 用 ; 在 函数 内 部 定义 的 局 部 变量 ,其 作用 域 局 限于 函 
数 内 部 ,不 能 在 主 程序 中 使 用 。 例 如 : 





<?php 

$my_var = "test"; //$ my_var 的 作用 域 局 限于 主 程序 

function my_func() 
$ local_var = 123; //$ local_var 的 作用 域 局 限于 当前 函数 
echo '$ local_var = '. $ local_var."<br>";  // 输 出 : $ local_var = 123 
echo '$ my_var= '. $ my_var. "<br>"; // 显 示 变 量 未 定义 

} 

my_func(); 

echo '$ my_var= '. $ my_var. "<br>"; // 输 出 : $ my_var = test 

echo '$ local_var = '. $ local_var."<br>"; // 显 示 变 量 未 定义 


在 函数 内 部 定义 的 局 部 变量 ,又 可 分 为 自动 变量 和 静态 变量 。 在 函数 内 部 使 用 static 
声明 的 变量 称 为 静态 变量 ; 否则 , 称 为 自动 变量 。 自 动 变量 与 静态 变量 的 区 别 是 : 对 于 自 
动 变量 ,每 调用 一 次 函数 ,都 会 为 自动 变量 分 配 存储 单元 ,函数 调用 结束 ,自动 变量 所 占 存 储 
单元 全 部 释放 。 对 于 静态 变量 ,第 一 次 调用 函数 时 ,为 静态 变量 分 配 存储 单元 ,函数 调用 结 
东 , 静 态 变 量 所 占 存储 单元 不 会 释放 。 例 如 : 


<?php 

function vars() 

{ 
$a=0; //$ a 为 自动 变量 
static $b=0; //$b 为 静态 变量 
$ at+; 
S$ b+t+; 
echo " $a, $b"."<br>"; 

} 

for ($i=1;$i<=3;$i++) 
vars(); 


程序 解释 : 第 1 次 调用 vars 函数 时 , $a、$b 的 初 值 为 0, 第 1 次 调用 结束 时 , $a 二 1， 
$b 二 1。 返 回 主 程序 时 , $ a 被 释放 .但 $b 不 释放 , 仍 保留 原 值 。 第 2 次 调用 vars 函数 时 ， 
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$a 的 初 值 为 0,$b 的 初 值 为 1; 第 2 次 调用 结束 时 , $a=1,$b=2。 第 3 次 调用 vars 函 
数 时 ,$a 的 初 值 为 0, $b 的 初 值 为 2; 第 3 次 调用 结束 时 , $a 一 1,$b 一 3。 

(2) 全 局 变量 

在 主 程序 中 定义 的 局 部 变量 ,如 果 想 在 函数 内 部 使 用 ,可 以 在 函数 内 部 使 用 global 关 
键 字 先 声 明 为 全 局 变量 ,和 否则 视 为 另外 定义 一 个 新 的 局 部 变量 。 声 明 全 局 变量 的 语句 为 





global 变量 名 ; 
声明 全 局 变量 ,并 没有 为 变量 分 配 存储 单元 。 
例如 : 
<?php 
$a = 123; // 此 变量 的 作用 域 目前 仅 限于 当前 主 程序 
function fun() 
{ 
$a = 456; // 这 个 变量 有 别 于 前 面 那个 $a, 它们 是 两 个 不 同 的 变量 
echo $a."<br>"; // 输 出 : 456 
global $a; // 将 主 程序 定义 的 $a 声明 为 全 局 变量 
echo $a."<br>"; // 输 出 : 123 
$a= 789; // 为 主 程序 定义 的 $a 赋值 为 789 
} 
fun(); 
echo $a; // 输 出 : 789 


?> 

2.3.2 预定 义 变量 

PHP 预 设 了 若干 个 数组 ,其 中 存储 了 运行 环境 .用户 输入 数据 等 , 称 为 预定 义 变量 ,其 
作用 域 是 全 局 自动 有 效 。 预 定义 变量 主要 有 以 下 几 种 。 

1. 服务 器 变量 $_SERVER 

服务 器 变量 是 由 Web 服务 器 创建 的 数组 ,其 内 容 包括 文件 的 头 信息 .路 径 、 脚 本 位 置 等 
信息 ,常用 的 几 个 服务 器 变量 见 表 2-2。 

表 2-2 常用 的 服务 器 变量 


服务 器 变量 名 


变量 的 存储 内 容 





$ _SERVER[ 'HTTP_USER_AGENT'] 


用 户 使 用 的 浏览 器 信息 





$ _SERVER[ 'HTTP_HOST '] 


host 头 信息 ,如 localhost 





$_SERVER[ ‘SERVER_NAME'] 


服务 器 主机 的 名 称 , 如 localhost 





$_SERVER[ 'SERVER_ADDR'] 


服务 器 的 IP 地 址 ,如 127. 0. 0. 1 





$ _SERVERL 'SERVER_PORT'] 


服务 器 的 端口 号 ,如 80 





$ _SERVER[L ‘REMOTE_ADDR '] 


当前 浏览 的 用 户 的 IP 地 址 











$ _SERVER[ 'DOCUMENT_ROOT] 文档 根 目 录 
$ _SERVERL[L 'SCRIPT_FILENAME'] 当前 执行 脚本 的 绝对 路 径 名 
$ _SERVER[ 'REMOTE_PORT'] 用 户 连接 到 服务 器 时 使 用 的 端口 号 





$ _SERVER[ 'QUERY_STRING '] 


URL 中 的 请 求 字符 串 








$ _SERVER[ ‘REQUEST_URI'] 





访问 此 页 面 所 需 的 URI 
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续 表 
服务 器 变量 名 变量 的 存储 内 容 
$_SERVER[ 'SCRIPT_NAME'] 包含 当前 脚本 的 路 径 
$_SERVER[ 'PHP_SELF '] 当前 正在 执行 脚本 的 文件 名 
$ _SERVER[ 'REQUEST_TIME '] 请 求 开始 时 的 时 间 惟 
$ _SERVER[ 'REQUEST_TIME_FLOAT'] 同上 ,精确 到 微 秒 (PHP 5. 4. 0) 





2. 环境 变量 $_ENV 

环境 变量 记录 着 PHP 运行 环境 相关 的 信息 ,如 系统 名 、 系 统 路 径 等 。 可 以 通过 
$_ENVL ' 成 员 变 量 名 '] 的 方式 来 访问 环境 变量 ,常用 的 成 员 变量 名 有 OS、Path 等 。 

如 果 PHP 是 测试 版 本 ,使 用 环境 变量 时 可 能 会 出 现 找 不 到 环境 变量 的 问题 。 解 决 办 
法 是 ,打开 php. ini 配置 文件 ,找到 variables_order 二 "GPCS" 所 在 行 , 将 该 行 改 成 variables_ 
order 二 "EGPCS" ,然后 保存 ,并 重启 Apache。 

3. 全 局 变量 $ GLOBALS 

$ GLOBALS 变量 以 数组 形式 记录 所 有 已 经 定义 的 全 局 变量 。 可 以 通过 $GLOBALS 
[ "变量 名 人 访问 程序 的 所 有 全 局 变量 , 它 比 使 用 global 访问 全 局 变量 更 方便 。 例如: 

<?php 

$a=1; 
$b=2; 
function fun() 
{ 
global $a; // 使 用 global 声明 全 局 变量 $a 
$a= $a+10; 
$ GLOBALS[ 'b'] = $ GLOBALS[ 'b'] + 10; ”// 使 用 $ GLOBALS 声明 全 局 变量 $b 
} 
fun(); 


echo " $a, $b"; 
?> 


另外 ,PHP 的 预定 义 变量 还 有 : $_COOKIE、 $ _GET,、 $_POST. $ _FILES、 $ _REQUEST、 
$_SESSION 等 ,这 些 变量 将 会 在 后 面 章节 中 介绍 。 
2.3.3 外 部 变量 


在 PHP 中 ,把 程序 中 定义 的 变量 叫 内 部 变量 ,而 把 表单 中 的 变量 ( 即 控件 名 称 )、URL 
中 的 参数 名 叫 外 部 变量 ,其 值 通 过 预定 义 变量 $_POST、$_GET、$_REQUEST 获得 。 
。 $_POST[ "表单 变量 "]: 取得 从 客户 端 以 POST 方式 传递 过 来 的 表单 变量 的 





value 值 。 
。$_GET[ "表单 变量 "]: 取得 从 客户 端 以 
GET 方式 传递 过 来 的 表单 变量 的 value 值 。 。 客 P 端 ”ww ， 服务 器 
| 才 单 变量 - 值 | $ REQUEST 
。 $_REQUEST[ "表单 变 量 "]: 取得 从 客户 端 和, 














以 任意 方式 传递 过 来 的 表单 变量 的 value 值 ， 
如 图 2-1 所 示 。 2-1 服务 器 接收 数据 示意 图 
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。$_REQUEST[" 参 数 名 "]: 取得 从 客户 端 传递 过 来 的 参数 值 。 

【 例 2-1】 分 别 用 POST 和 GET 方式 提交 表单 ,使 用 $_POST、$ _GET 接收 表单 变 
量 的 值 。 

新 建 EX2-1. php 网 页 ,输入 以 下 代码 。 


< html > 
<head> 
<meta http— equiv = "Content - Type" content = "text/html; charset =utf -8" /> 
</head> 
<body> 
< form name = "forml" method = "post" action = ""> 
用 POST 发 送 的 学 号 : 
< input type= "text" name = "XH" id = "XH" /> 
< input type = "submit" name = "button1" value = "提交 " /> 
</form> 
<form name = "form2" method = "get”action = ""> 
用 gnbsp; GET 发送 的 姓名 : 
< input type = "text" name = "XM" id = "XM" /> 
< input type = "submit" name = "button2" value = "提交 " /> 
</form> 
<?php 
// 使 用 $ _POST 接收 表单 变量 的 值 
if(isset( $_POST[ "buttonl '])) 
echo ' 学 号 : '. $ _POST[ 'XH']; 
// 使 用 $ _GET 接收 表单 变量 的 值 
if(isset( $_GET[ ‘button2'])) 
echo ' 姓 名 : '. $ _GET[ 'XM']; 





?> 
</body > 
</html > 


2.4 运算 符 与 表达 式 


PHP 的 运算 符 与 C 语言 基本 相同 ,也 引进 15 级 运算 符 。 表 2-3 列 出 了 PHP 中 常用 的 
表 2-3 PHP 中 常用 的 运算 符 






































优先 级 运 算 符 描 述 结合 性 
1 O) 圆 括号 
学 和 二 一 y= 自 增 、 自 减负 号 .逻辑 非 非 结 合 
3 *,/,% 乘除 . 取 余 从 左 向 右 
4 十 ,一 加 \ 减 从 左 向 右 
< 过, 之 这 左 移 、 右 移 从 左 向 右 
6 >,>=,<.<= 大 于 ,大 于 等 于 .小 于 .小 于 等 于 非 结 合 
7 一 一 ,! 一 等 于 .不 等 于 非 结 合 
8 &. 按 位 与 从 左 向 右 
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续 表 

优先 级 运 算 符 描 述 结合 
9 ^ 按 位 异 或 从 左 向 右 
10 | 按 位 或 从 左 向 右 
11 &.& 逻辑 与 从 左 向 右 
12 1 逻辑 或 从 左 向 右 
13 ?: 条 件 运 算 符 从 右 向 左 
14 二 ,十 二 ,一 二 ,* 二 ,/ 二 ,% 二 | 赋值 运算 符 从 右 向 左 

15 @ 错误 控制 运算 符 非 结 合 











下 面 介绍 各 类 运算 符 的 用 法 。 
1. 算术 运算 符 
(1) 双 目 运算 符 : 十 ,一 ,x ,/,% 
当 */” 两 侧 为 整数 时 ,结果 为 整数 或 浮 点 数 ; 当 *%” 两 侧 为 浮 点 数 时 , 舍 去 小 数 部 分 取 
整 , 结 果 为 整数 。 
(2) 单 目 运算 符 : 十 十 ( 自 增 ) ,一 一 ( 自 减 ) 
Q@ + 十 十 ,一 一 只 能 作用 在 变量 上 ,不 能 作用 在 常量 和 表达 式 上 。 
@ $i 十 十 ,十 十 $i 单独 成 为 语句 时 ,均等 价 于 $i= $i 十 1。 
@ $i 十 十 ,十 十 $i 的 不 同 之 处 是 : $i 十 十 是 先 返 回 $i, 再 使 $i 的 值 加 1; 十 十 $i 则 
是 先 使 $i 的 值 加 1, 再 返回 $i。 
【 例 2-2】 分 析 程 序 的 运行 结果 。 
<?php 
$1i=3; 
$j= $it+; 
echo "$i, $j",."<br>"; 
$i=3; 
$j=++$i; 
echo " $i, $j"; 
?> 
运行 结果 : 


4,3 


算术 运算 符 的 优先 级 见 表 2-4。 
表 2-4 算术 运算 符 的 优先 级 














运算 符 优先 级 结合 性 
十 十 ,一 一 2 级 非 结合 

x* 1/,% 3 级 从 左 向 右 
Es 4 级 从 左 向 右 
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由 算术 运算 符 组 成 的 表达 式 称 为 算术 表达 式 ,算术 表达 式 的 值 是 一 个 整数 或 浮 点 数 。 
2. 关系 运算 符 
关系 运算 符 的 优先 级 见 表 2-5。 
表 2-5 关系 运算 符 的 优先 级 

















运 算 符 优先 级 结合 性 
>,>=,<,<= 6 级 非 结 合 
三 二 = 7 级 非 结合 





关系 运算 符 表示 对 操作 数 的 比较 运算 ,由 关系 运算 符 组 成 的 表达 式 称 为 关系 表达 式 。 
关系 表达 式 的 值 为 true 或 false, 例 如 ,7 二 ==7 的 值 为 true。 

注意 : 如 果 数 值 和 字符 串 进行 比较 , 则 字符 串 先 被 转换 成 数值 再 进行 比较 ; 如 果 两 个 
数字 字符 串 进行 比较 , 则 它们 都 会 被 当成 数值 来 比较 。 例 如 : 


<?php 
var_dump(123.5 >"abc"); // 实 际 比较 的 是 123.5 和 0, 输出 true 
var_dump("123.5">"9. 5"); // 实 际 比较 的 是 123.5 和 9.5, 输 出 true 
var_dump("abc">"z"); // 实 际 比较 的 是 "abc" 和 "z", 输 出 false 

?> 

3. 逻辑 运算 符 


逻辑 运算 符 的 优先 级 见 表 2-6。 
表 2-6 逻辑 运算 符 的 优先 级 




















运算 符 优先 级 举 例 解 释 
! 2 级 I$x 

&& 11 级 $x&&$y 只 要 $x, $y 有 一 个 为 假 ,结果 就 为 假 
| 12 级 $xl $y 只 要 $x, $y 有 一 个 为 真 ,结果 就 为 真 


参加 人 逻辑 运算 的 操作 数 必须 为 逻辑 值 。 由 人 逻辑 运算 符 组 成 的 表达 式 称 为 逻辑 表达 式 。 
逻辑 表达 式 值 为 true 或 false, 例 如 ,2 十 3 二 7 &&&. 7 一 9 是 一 个 逻辑 表达 式 , 它 的 值 为 false。 

若 一 个 表达 式 含有 各 类 运算 符 , 则 表达 式 的 类 型 取决 于 级 别 最 低 的 运算 符 的 类 型 。 

4. 条 件 运算 符 

PHP 中 唯一 的 一 个 三 目 运算 符 就 是 条 件 运算 符 (?:) ,由 条 件 运算 符 组 成 的 表达 式 称 为 
条 件 表达 式 ,条 件 表 达 式 的 一 般 格 式 为 : 

操作 数 1? 操 作 数 2: 操作 数 3 
其 中 ,操作 数 1” 的 值 必 须 为 逻辑 值 .否则 将 出 现 编译 错误 。 进 行 条 件 运 算 时 ,首先 判断 “ 操 
作 数 1” 是 否 为 真 ,如 果 “ 操 作 数 1” 为 真 , 则 条 件 表达 式 的 值 为 “操作 数 2” 的 值 ; 如 果 “ 操 作 数 1” 
为 假 , 则 条 件 表达 式 的 值 为 "操作 数 3” 的 值 。 例 如 ,已 知 $a=3, $b=5, 则 $a 二 $b?$a:$b 
的 值 为 5。 

注意 : 条 件 表达 式 具有 “ 右 结 合 性 ”, 意 思 是 操作 从 右 向 左 组 合 。 例 如 , $a?$b: $c?$d: 
$e 表达 式 的 计算 与 $a?$b:($c?$d:$e) 相 同 。 


5. 赋值 运算 符 
(1) 赋值 运算 符 
赋值 运算 符 包括 三 、 十 二 、 一 二 、* 二 、/ 二 、% 二 ,它们 的 优先 级 为 14 级 ,结合 性 是 从 右 
向 左 的 。 例 如 ,$a 二 $b 二 $c 二 4; 语 名 表示 $a、$b、$c 的 值 均 为 4。 
表 2-7 列 出 了 复合 赋值 运算 符 的 含义 。 
表 2-7 复合 赋值 运算 符 
































赋值 运算 符 举 例 会 美 
十 = $at+= $b $a=$at+ $b 
一 一 $a—= $b $a=$a— $b 
# 一 $ax* 一 $b $a=$ax $b 
/= $a/= $b $a=$a/$b 
得 一 $a%= $b $a=$a% $b 








(2) 赋值 表达 式 

赋值 表达 式 的 值 等 于 被 赋值 的 变量 的 值 。 例 如 ,表达 式 $a 二 5 的 值 为 5。 

6. 错误 控制 运算 符 

PHP 支持 错误 控制 运算 符 @ ,将 其 放置 在 PHP 表达 式 之 前 ,该 表达 式 可 能 产生 的 任何 
错误 信息 都 将 被 忽略 。 

注意 : 当 要 使 用 的 变量 名 的 值 为 NULL 时 ,就 必须 在 变量 名 前 面 加 @。 

小 结 : PHP 常用 运算 符 可 分 为 6 类 : 算术 运算 符 、 关 系 运算 符 、 远 辑 运算 符 、 条 件 运 算 
符 、 赋 值 运算 符 、 错 误 控 制 运算 符 。 


2.5 程序 流程 控制 
PHP 的 流程 控制 语句 大 多 与 C 语言 一 致 , 仅 有 个 别 不 同 。 
条 件 控制 语句 
条 件 控制 的 典型 语句 有 f 语 句 和 switch 语句 。 
1. 语句 
证 语句 的 语法 格式 如 下 : 
if (表达 式 ) 语 句 1 [else 语句 2] 
当 表达 式 为 真 时 ,就 执行 “语句 1”, 和 否则 执行 "语句 2”。 其 中 , “语句 1”“ 语 句 2” 可 以 是 
任意 一 个 PHP 语句 。 例 如: 
if ($a> $b) $max = $ a; else $max = $b; 
上 面 格式 中 的 方 括号 [ ] 表 示 车 不 需要 可 以 省 略 ,本 书后 面 还 有 这 种 情况 ,这 里 不 再 效 述 . 
2. if 语句 的 庶 套 
计 语 句 一 般 用 于 解决 单 分 支 \ 双 分 支 问题 ,必要 时 ,也 可 以 解决 多 分 支 问题 。 


2:5:1 
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让 语 句 的 嵌 套 格式 如 下 : 


if (表达 式 1) 语句 1 
elseif (表达 式 2) 语句 2 
elseif (表达 式 3) 语句 3 


else 语句 n 


注意 : 在 PHP 中 ,可 以 写成 elseif, 也 可 以 隔 开 写 成 else if。 

【 例 2-3】 编写 一 个 PHP 程序 ,从 文本 框 输 入 一 个 百分制 分 数 , 单 击 “ 提 交 ” 按 钮 后 输出 成 
绩 等 级 。90 分 以 上 记 'A',80~89 分 记 'B',70~79 分 记 'C',60~69 分 记 'D',60 分 以 下 记 ''。 

新 建 EX2-3. php 网 页 ,输入 以 下 代码 。 


<! DOCTYPE html > 
<form id = "forml" name = "forml”" method= "post" action= ""> 
< input type = "text" name = "score" id = "score" /> 


< input type = "submit" name = "button” id= "button" value = "提交 " /> 
</form> 
<?php 
if (isset( $ _REQUEST[ "button"])) 
{ $ score= $ _REQUEST["score"]; 
if ($ score>=90) $ grade= 'A'; 
elseif ( $ score>=80) $ grade = 'B’; 
elseif ( $ score>=70) $ grade= 'C'; 
elseif ( $ score>=60) $ grade= ‘D'; 
else $ grade= 'E’; 
echo "成 绩 等 级 为 ". $ grade; 
} 


?> 


3. switch 语句 


switch 语句 也 称 为 多 分 支 语句 , 它 可 以 根据 表达 式 的 值 来 决定 执行 哪个 case 块 的 语 
句 。switch 语句 的 语法 格式 如 下 : 


switch (表达 式 ) 
{ case 常量 1: 语句 块 1; 
[break; ] 
case 常量 2: 语句 块 2; 
[break; ] 


case 常量 n: 语句 块 n; 
[break; ] 
[ default: 语句 块 n+1; ] 
} 


首先 计算 表达 式 的 值 ,如 果 表 达 式 值 与 某 个 case 块 的 常量 相等 ,就 转 去 执行 该 case 块 
的 语句 , 当 表 达 式 值 与 任何 case 块 的 常量 都 不 相等 时 ,就 执行 default 中 的 语句 。 

注意 : 

(1) 表达 式 的 类 型 可 以 是 数值 型 或 字符 串 型 。 

(2) 多 个 不 同 的 case 可 以 执行 同一 个 语句 块 。 


【 例 2-4】 编写 一 个 PHP 程序 ,从 文本 框 输入 一 个 月 份 , 单 击 “ 提 交 ” 按 钮 后 输出 该 月 
份 的 天 数 。 
新 建 EX2-4. php 网 页 ,输入 以 下 代码 。 


<! DOCTYPE html > 
< form id = "forml" name = "forml" method= "post" action= ""> 
< input type = "text" name = "month" id = "month" /> 
< input type = "submit" name = "button” id= "button" value = "提交 " /> 
</form> 
<?php 
if (isset( $ _REQUEST[ "button"])) 
{ 
$ month= $ _REQUEST[ "month" ]; 
switch ( $ month) 
{ casel1: 
Case 3: 
case 5: 
case 7: 
case 8: 
case 10: 
case 12: $day = 31; break; 
case 4: 
Case 6: 
case 9: 
case 11: $day = 30; break; 
case 2: $day = 28; break; 
default: $day = 0; 
} 
echo " $ month 月 份 的 天 数 为 : $ day"; 
} 


2.5.2 循环 控制 语句 

循环 控制 语句 简称 循环 语句 ,PHP 有 4 种 循环 语句 ,分 别 是 while 语句 、do-while 语句 、 
for 语句 ,foreach 语句 。 

1. while 语句 

while 语句 的 语法 格式 如 下 : 

while (表达 式 ) 语句 

【 例 2-5】 用 while 语句 求 1 一 100 的 偶数 。 

新 建 EX2-5. php 网 页 ,输入 以 下 代码 。 


<?php 
$s=0; 
$i1=2; 
while( $i<=100) 
{ 





$s= $s+ $i; 
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$i= $1i+2; 
} 
echo "和 为 : $ s"; 


?> 


2. do-while 语句 
do-while 语句 的 语法 格式 如 下 : 
do 
循环 体 语句 
while (表达 式 ); // 注 意 末 尾 有 分 号 
【 例 2-6】 用 do-while 语句 求 1 一 100 的 偶数 。 
新 建 EX2-6. php 网 页 ,输入 以 下 代码 。 
<?php 
$s=0; 
$1=2; 
do 
{ 
$s= $s+ $i; 
是 寻 灶 :是 名 本 改 
}while( $ i<= 100); 


echo "和 为 :$s"; 
?> 


注意 : while 语句 的 特点 是 : 先 判断 后 执行 ,可 能 一 次 也 不 执行 循环 体 。 而 do-while 语 
各 是 先 执行 后 判断 ,至 少 要 执行 一 次 循环 体 。 

3. for 语句 

for 语句 的 语法 格式 如 下 : 

for (表达 式 1; 表达 式 2; 表达 式 3) 循 环 体 语句 

for 语句 的 执行 过 程 如 图 2-2 所 示 。 
























































说 明 : 
了 
(1) 表达 式 1 常用 于 对 循环 变量 赋 初 值 ; 表达 式 2 常用 于 判 RR 
断 循环 变量 是 否 越过 终 值 ; 表达 式 3 常用 于 修改 循环 变量 的 值 。 
(2) 表达 式 1, 表 达 式 2, 表 达 式 3 都 可 以 省 略 ,但 分 号 不 能 省 人 
略 。 例 如 ,for (;;) 语 句 。 
【 例 2-7】 用 for 语句 求 1~100 的 偶数 。 4 这 
新 建 EX2-7. php 网 页 ,输入 以 下 代码 。 循环 体 
<?php 了 
$s=0; 表达 式 3 
for($i=2;$i<=100; $i+=2) 
$s= $s+ $i; 1 
echo "和 为 : $ s"; 
?> 


图 2-2 for 语句 


4. foreach 语句 
foreach 语句 用 于 列举 一 个 数组 中 的 所 有 元 素 。foreach 语句 的 语法 格式 如 下 
foreach( 数 组 名 as 成 员 名 ) 
语句 

功能 : 对 于 数组 中 的 每 个 元 素 ,都 重复 执行 循环 体 。 成 员 名 代表 数组 中 的 一 个 元 素 。 
下 面 的 代码 演示 了 foreach 语句 的 用 法 。 
<?php 

$a=array(3,6,9,12,15,18); 

foreach( $aas $x) 


echo " $x,"; 
?> 


2.5.3 跳 转 语句 


。 break 语句 : 中 止 并 跳出 循环 。 

。 continue 语句 : 终止 当前 的 循环 ,重新 开始 一 个 新 的 循环 。 

break 语句 只 能 用 于 switch 语句 中 或 循环 体内 , 当 break 语句 用 于 循环 体内 时 , 常 与 
证 语句 配合 使 用 。continue 语句 只 能 用 于 循环 体内 时 ,并 常 与 i 语句 配合 使 用 。 


2.5.4 文件 包含 语句 


在 一 个 PHP 文件 中 ,可 以 直接 用 ”文件 包含 语句 ”把 另 一 个 文件 的 所 有 内 容 包 含 进 当 
前 位 置 。 文 件 包含 语句 共有 4 种 ,其 关键 字 及 语法 格式 分 别 如 下 : 

include ' 文 件 名 

require ' 文 件 名 '; 

include_once ' 文 件 名 号 

require_once ' 文 件 名 7 

一 方面 ,include 及 require 表示 直接 把 文件 包含 进来 ; include_once 及 require_once 表 
示 只 把 文件 包含 进来 一 次 ,不 重复 包含 。 另 一 方面 ,include 及 include_once 当 找 不 到 被 包 
含 文件 时 ,浏览 器 会 发 出 警告 信息 但 仍 继续 执行 代码 ; require 及 require_once 当 找 不 到 被 
包含 文件 时 ,浏览 器 会 发 出 致命 错误 信息 并 中 止 执行 代码 。 

上 述 /文件 名 ' 均 可 采用 相对 路 径 或 绝对 路 径 两 种 方式 ,但 要 注意 的 是 ,路 径 分 隔 符 要 采 
用 和 斜 杠 (/) 来 表示 。 若 省 略 路 径 , 则 表示 仅 在 当前 目录 中 查找 文件 。 


2.6 PHP 函数 


函数 的 作用 就 是 让 同一 段 代码 可 以 被 多 个 地 方 直接 调用 ,从 而 大 大 节省 编程 时 间 减少 
编程 错误 ,容易 维护 代码 ,实现 结构 化 编程 。 函 数 分 为 系统 函数 和 自 定义 函数 。 
2.6.1 国 数 的 定义 


所 谓 函 数 的 定义 ,就 是 指 采 用 若干 行 代码 以 指明 此 郴 数 具 体 的 执行 过 程 以 及 执行 之 前 
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需要 输入 什么 参数 、 执 行 完成 后 可 以 返回 什么 值 。 
函数 定义 的 语法 格式 如 下 : 
function 函数 名 ([ 形 参 表 ]) 
{ 函数 体 } 
其 中 , 形 参 必须 是 变量 名 、 数 组 名 ; 函数 名 可 以 是 以 字母 或 下 画 线 开头 .后面 跟 任意 数量 的 
字母 .数字 .下 画 线 ,但 不 能 与 系统 函数 或 用 户 已 经 定义 的 函数 名 重 名 。 与 C 语言 不 同 的 
是 ,函数 定义 可 以 随意 放 在 函数 调用 语句 之 前 或 之 后 。 例 如 : 
<?php 
fun(4); // 输 出 : 8 
// 函 数 定义 放 在 函数 调用 之 前 或 之 后 均 可 


function fun( $a){ 





echo $a *#* 2; 
} 
fun(5); // 输 出 : 10 
?> 


2.6.2 函数 的 返回 值 

在 函数 定义 内 部 ,可 以 使 用 return 语句 来 结束 函数 的 运行 ,并 把 一 个 值 返 回 给 主 调 语句 。 
return 语句 的 语法 格式 如 下 : 

return [ (表达 式 )]; 

功能 : 将 表达 式 的 值 (作为 函数 值 ) 带 回 主 调 函 数 中 。 

2.6.3 国 数 的 调用 


函数 调用 有 如 下 三 种 形式 。 

(1) 函数 名 ( 实 参 表 ) 。 

(2) 变量 名 三 函数 名 ( 实 参 表 )。 

(3) echo 函数 名 ( 实 参 表 )。 

注意 : 

(1) 形式 (1) 用 于 调用 无 返回 值 的 函数 ,形式 (2)、(3) 用 于 调用 有 返回 值 的 函数 。 
(2) 实 参 的 个 数 、 类 型 必须 与 形 参 相同 。 

(3) 实 参 可 以 是 常量 变量、 表达 式 。 


【 例 2-8】 已 知 : 
1 (zx>0) 
,1 (z= 0) 


= (人 六 和) 
要 求 : 先 定义 一 个 函数 fun(), 用 于 返回 y 的 值 ; 再 写 一 个 函数 调用 语句 ,输出 y 的 值 。 
程序 代码 如 下 : 


<?php 
function fun( $ x) 








if ($x>0) $y=1; 
elseif ($x==0) $y=0; 
else $y= 一 1; 

return( $ y); 


} 
echo fun(10); 
?> 


2.6.4 参数 的 传递 

函数 参数 一 般 都 是 通过 值 来 传递 的 ,这 意味 着 在 函数 内 部 即使 修改 了 形 参 的 值 ,也 不 会 
对 主 调 语句 中 的 实 参 有 影响 。 但 是 , 当 函 数 形 参 采用 引用 参数 时 , 则 任何 对 于 形 参 的 值 的 修 
改 都 相当 于 对 实 参 的 值 的 修改 。 引 用 参数 的 语法 格式 是 在 形 参 前 面 加 & 字符 。 



































值 传递 和 引用 传递 的 比较 见 表 2-8。 
表 2-8 值 传递 和 引用 传递 的 比较 
方 式 形 参 实 参 解释 
信息 入 变量 名 常量 ,变量 ,表达 式 函数 调用 时 ,将 实 参 的 值 传递 给 
数组 名 数组 名 形 参 
本 & 变量 名 变量 名 形 参与 实 参 共同 占用 一 个 存储 
& 数组 名 数组 名 单元 
下 面 函数 的 形 参 为 变量 名 。 
<?php 


function fun(&$ x, $y) 
{ 
$x+= 10; 
$yt+=10; 
} 
$a=1; 
$b=5; 
fun( $a, $b); 
echo "$a, $b"; // 输 出 : 11,5 
?> 


下 面 函 数 的 形 参 为 数组 名 。 


<?php 

function my_sort( $ b) 

{ for( $i=0;$i<count( $b); $i++) 

$b[ $i]+= 10; 

} 

$a=array(2,4,6,8); 

my_sort( $a); 

for( $i=0; $i<count( $a);$ it+) 

echo $al $1].","; // 输 出 : 2,4,6,8 

?> 
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本 节 通 过 两 个 综合 实例 来 说 明 PHP 的 控制 语句 及 函数 使 用 。 
2.7.1 多 项 选择 题 


【 例 2-9】 设计 一 个 网 页 ,询问 用 户 “ 下 列 哪些 城市 属于 省 会 城市 ”, 并 列 出 若干 城市 
(广州 .成 都 ,北京 ,福州 重庆, 沈阳) 以 供 选 择 。 用 户 单 击 “提交 ”按钮 时 ,提示 答案 是 否 正确 
(正确 答案 应 该 是 : 广州 .成 都 ,福州 沈阳 )。 

新 建 EX2-9. php 网 页 ,输入 以 下 代码 。 


<html> 
<head> 
<meta http— equiv = "Content - Type" content = "text/html; charset = utf - 8" /></head> 
<body> 
<p> 下 列 哪些 城市 属于 省 会 城市 ? </p> 
< form name = "forml" method = "post" action= ""> 
< input type = "checkbox" name = "answer[ ]" value = "A"> 广 州 <br /> 
< input type = "checkbox" name = "answer[ ]”value = "B"> 成 都 <br /> 
< input type = "checkbox" name = "answer[ ]”value = "C"> 北 京 <br /> 
< input type = "checkbox" name = "answer[ ]”value = "D"> 福 州 <br /> 
< input type = "checkbox" name = "answer[ ]" value = "E"> 重 庆 < br /> 
< input type = "checkbox" name = "answer[ ]" value = "F"> 沈 阳 < br /> 
< input type = "submit" name = "submit” id= "submit” value = "提交 "> 
</form > 
<?php 
if(isset( $ _POST[ 'submit '])){ 
// 得 到 一 个 数组 $answer, 仅 包含 用 户 选 中 的 项 
$answer = $_POST[ 'answer']; 
$ choice = 


党 


for($i = 0; $i<count( $answer); $ i++) 


$choice . = $answer[ $i]; 
if( $ choice == ‘ABDF') 

show( ' 恭 喜 你 ,答对 了 ! '); 
else 


show( ' 不 对 ,重新 答 !'); 
} 
// 自 定义 函数 ,用 于 弹出 提示 框 , 显示 提示 
function show( $ message) { 


echo "< script >alert('$ message')</script >"; 


网 页 的 运行 效果 如 图 2-3 所 示 。 
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广州 来 自 网 页 的 消息 。 “(区 | 
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图 2-3 多 项 选择 题 网 页 效果 


网 页 中 ,表单 里 的 复 选 框 中 的 name 全 部 都 为 "answer[]", 这 样 ,在 PHP 代码 中 ， 
$_POST[ 'answer'] 取 到 的 是 一 个 数组 ,数组 中 的 所 有 元 素 仅 由 用 户 选中 的 那些 复 选 框 组 
成 ,而 元 素 的 值 则 是 该 复 选 框 的 value 的 值 。 本 程序 中 通过 把 所 有 被 用 户 选 中 的 复 选 框 中 
的 value 的 值 连接 起 来 ,形成 一 个 字符 串 , 从 而 用 于 与 标准 答案 的 比较 ,可 方便 地 判断 答案 
是 否 正确 。 

本 程序 中 ,还 自 定 义 了 一 个 函数 show, 用 于 在 网 页 中 显示 提示 信息 。 在 函数 show 中 ， 
采用 JavaScript 语言 来 显示 提示 。 有 关 JavaScript 的 编程 ,参见 5. 4 节 内 容 。 


2.7.2 计算 器 程序 


【 例 2-10】 设计 一 个 网 页 ,让 用 户 输入 一 个 四 则 运算 式 , 采 用 下 拉 列 表 提 供 加 , 减 、 乘 、 
除 4 种 运算 符 。 当 用 户 单 击 * 求 值 "按钮 时 ,自动 计算 结果 并 显示 出 提示 信息 。 
新 建 EX2-10. php 网 页 ,输入 以 下 代码 。 


< html > 
<head> 
<meta http - equiv = "Content - Type" content = "text/html; charset = utf- 8" /> 
</head> 
<?php 
if(isset( $ _POST[ 'submit '])){ 

$a = $_POST['a']; 

$b = $_POST['b']; 

$ opr = $_POST[ 'opr']; 


$c = "0", 
calc( $a, $opr, $b, $c); // 计 算 
show( "$a $opr $b = $c"); // 显 示 


} 

// 用 于 计算 一 个 四 则 运算 式 ,结果 存储 于 $c 

function calc( $a, $0opr, $b, &$c){ 
switch( $ opr){ 


case “十 ": 

$c= $a+ $b; break; 
Case —': 

$c= $a— $b; break; 
Case #°: 

$c= $a* $b; break; 
case '/': 


$c= @($a/ $b); break; 


default: 
$c= ""; 
} 
下 
// 自 定义 函数 ,用 于 弹出 提示 框 , 显示 提示 
function show( $ message){ 
echo "< script >alert( '$ message')</script >"; 
} 
?> 
<body> 
<p> 四 则 运算 计算 器 </p> 
< form name = "forml" method = "post" action = ""> 
< input name = "a" type = "text" id= "a" size= "6"> 
< select name = "opr" id = "opr"> 
< option>+ </option> 
< option>- </option> 
< option>* </option> 
< option >/</option> 
</select > 
< input name = "b" type = "text" id= "b" size= "6"> 
<input type = "submit" name = "submit” id= "submit”value = " 求 值 "> 





</form> 
</body > 
</html > 
网 页 的 运行 效果 如 图 2-4 所 示 。 
四 则 运算 计算 器 一 
来 自 网 页 的 消息 区 
日 * 国 |3 























2-4 计算 器 程序 网 页 效果 
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程序 中 ,首先 读 入 用 户 输入 的 两 个 运算 数 $a、$b 以 及 一 个 运算 符 $opr, 调 用 自 定义 


函数 calc 计算 结果 $c, 然 后 调用 show 自 定义 函数 显示 出 结果 。 


自 定义 函数 calc 中 的 第 3 个 参数 是 引用 参数 ,用 于 返回 结果 。 函 数 中 采用 switch-case 


结构 进行 判断 ,效果 比 计 好 。 


程序 中 calc 函数 中 有 一 个 地 方 采用 @ 命 令 , 防 止 除法 发 生 错 误 时 在 浏览 器 上 显示 一 大 


堆 错误 信 息 ,造成 界面 被 破坏 。 
2.8 项 目 实 训 


实 训 1 条 件 控制 语句 的 应 用 


实 训 目的 
(1) 掌握 条 件 控制 语句 的 语法 。 
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(2) 掌握 条 件 控制 语句 的 应 用 特点 。 

(3) 学 会 在 PHP 脚本 中 使 用 表单 控件 。 

实 训 要 求 

创建 一 个 名 为 sx2-1. php 的 网 页 ,让 用 户 选 择 自己 的 爱好 ,采用 多 个 复 选 框 分 别 列 出 
“打球 、 下 棋 \ 唱 歌 .跑步 阅读 ” 几 个 选项 (其 中 “打球 .唱歌 .跑步 * 属 于 偏 动 的 项 目 , 其 余 的 属 
于 偏 静 的 项 目 )。 当 用 户 单 击 “提交 ”按钮 后 ,判断 用 户 选 的 项 目 分 别 属于 什么 类 型 ,最 后 提 
示 用 户 :“ 你 是 一 个 好 动 的 人 “你 是 一 个 好 静 的 人 “你 是 一 个 动静 皆 宜 的 人 ”。 初 始 界 面 如 
图 2-5 所 示 。 








你 的 爱好 是 ， 

河 打 球 百 下 异 百 晶 歌 百 更 步 日 阅读 ; 

人 
图 2-5 初始 界面 


实 训 2 循环 控制 语句 的 应 用 


实 训 目的 
(1) 掌握 循环 控制 语句 的 语法 。 
(2) 掌握 循环 控制 语句 的 应 用 特点 。 
(3) 学 会 在 PHP 脚本 中 使 用 表单 控件 。 
实 训 要 求 
创建 一 个 名 为 sx2-2. php 的 网 页 ,让 用 户 输入 两 个 数 以 表示 一 个 范围 ,程序 求 出 该 范围 
内 的 所 有 素数 ,并 显示 在 下 面 。 运 行 效果 如 图 2-6 所 示 。 
求 区 间 素 数 
请 输入 范围 , 
州 “| 到] 臣 到 





图 2-6 输入 40.60 单 击 “ 提 交 ” 按 钮 后 的 界面 





思考 与 练习 

一 、 填空 题 

1. 一 个 PHP 文件 由 和 三 部 分 组 成 ,前 两 部 分 在 客户 端 
运行 。 

2. 在 PHP 中 ,把 表单 中 的 变量 ( 即 控件 名 称 )、URL 中 的 参数 名 叫 变量 ,其 值 


通过 预定 义 变量 获得 。 
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二 、 简 答题 

1. 字符 串 使 用 单 引号 与 双 引 号 作为 定 界 符 有 什么 区 别 ? 
2. PHP 中 的 自 定义 函数 与 C 语 言 有 什么 区 别 ? 

3 写 出 下 面 程序 的 运行 结果 。 


<?php 
function my_sort(&$ b) 
{ for($ i=0;$i<count( $b); $ i++) 
$b[ $i]+=10; 
} 
$a=array(2,4,6,8); 
my_sort( $a); 
for($i=0;$i<count( $a);$ i++) 
echo $al $i].","; 
?> 
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数组 和 字符 串 是 PHP 中 最 为 重要 的 两 种 数据 类 型 , 曾 有 人 做 过 统计 ,在 PHP 的 项 目 
开发 中 ,至 少 有 30% 的 代码 要 处 理 数 组 , 男 有 30% 以 上 的 代码 在 操作 字符 串 , 两 者 合计 占 
PHP 代码 比重 高 达 60% 以 上 , 故 本 童 专门 讲述 这 两 类 数据 的 操作 。 


GE eoee 


。 掌握 PHP 数组 的 定义 与 操作 。 
。 掌握 PHP 字符 串 的 定义 与 操作 。 
。 了 解 正则 表达 式 及 其 使 用 。 


3.1 数组 及 处 理 


数组 把 若干 数据 有 序 地 组 织 在 一 起 。 本 节 介 绍 如 何 创建 和 初始 化 数组 ,以 及 对 数组 的 
各 种 处 理 。 

3.1.1 数组 的 创建 和 初始 化 

1. 使 用 array( ) 函 数 创建 一 维 数组 

使 用 array() 函数 的 语法 格式 如 下 : 

数组 名 = array([ 键 名 =>] 值 , …,[ 键 名 =>] 值 ); 

每 个 元 素 包括 键 名 和 值 两 项 , 键 名 可 以 是 整数 或 字符 串 。 如 果 全 部 值 未 指定 键 名 , 则 键 


名 默认 为 从 0 开始 的 连续 整数 。 如 果 只 有 某 些 值 未 指定 键 名 , 则 该 值 的 键 名 默认 为 该 值 前 
面 最 大 的 整数 键 名 加 1 后 的 整数 。 例 如 : 
<?php 


$arrl =array(1,2,9,10); // 定 义 不 带 键 名 的 数组 
$ arr2 = array("color" =>"blue", "name" =>"pen"); // 定 义 带 键 名 的 数组 
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$arr3=array(1=>5, 2=>6, 4=>1, 9, 10); // 个 别 元 素 没有 键 名 
?> 
说 明 : 数组 $arrl 的 键 名 为 整数 键 名 ,分 别 为 0.1.2.3。 数 组 $arr2 的 键 名 为 字符 串 键 
名 ,分 别 为 "color" 和 "name"。 数 组 $arr3 的 键 名 分 别 为 1 .2、4、5、6。 
对 于 数组 ,在 调试 程序 时 可 以 用 print_r 函数 来 显示 数组 各 元 素 的 键 名 和 值 ,print_r 函 
数 的 语法 格式 如 下 : 
print_r( 数 组 名 ) 





例如 : 
<?php 
$arrl=array("a" =>5,"b" =>10,20); 
print_r( $ arrl); // 输 出 : Array ( [al =>5[b] =>10[0] =>20) 


echo "<br>"; 
$arr2 = array(2 =>4, "color" =>"red", 5, 3 =>7); 
print_r( $ arr2); // 输 出 : Array ( [2] =>4 [color] =>red[3] =>7) 
?> 
注意 : 在 数组 $arrl 中 ,第 3 个 值 20 的 键 名 为 0; 在 数组 $arr2 中 ,第 3 个 值 5 被 系统 
自动 设置 键 名 为 3, 但 是 由 于 后 面 又 有 3 一 二 7 自 定义 了 一 个 键 名 3, 因 此 后 面 的 值 7 覆盖 了 
前 面相 同 键 名 的 值 。 
数组 创建 之 后 ,可 以 使 用 “数组 名 [ 键 名 ]” 的 形式 来 访问 一 维 数组 元 素 , 例 如 : 


?php 
$arrl=array("a" =>5,"b" =>10,20); 
echo $ arrl["a"]; // 输 出 : 5 
echo $ arrl["b"]; // 输 出 : 10 
echo $arrl[0]; // 输 出 : 20 
> 
数组 创建 之 后 ,可 以 使 用 count() 和 sizeof() 函 数 获得 数组 元 素 的 个 数 , 例 如 : 
<?php 
$array =array(1,2,3,6=>7,8,9,5,10); 
echo count( $ array); // 输 出 : 8 
echo sizeof( $ array); // 输 出 : 8 
?> 


2. 使 用 array() 函 数 创建 二 维 数组 
通过 对 array() 函 数 的 能 套 使 用 ,可 以 创建 二 维 数组 ,语法 格式 如 下 : 
数组 名 = array( [ 键 名 1=>] array( 值 1, .…' 值 n)， 
[ 键 名 2=>] array( 值 1,-… 值 n) 
) 
说 明 : 内 层 的 每 个 array() 函数 表示 一 行 , 键 名 表示 行 号 。 若 省 略 键 名 , 则 默认 为 从 0 
开始 的 连续 整数 。 
二 维 数组 元 素 的 表示 形式 如 下 : 


数组 名 [ 键 名 1][ 键 名 2] 
例如 : 


<?php 
$ arrl = array("color" =>array(" 红 色 ", "绿色 "," 蓝 色 ")， 
"number" =>array(1,2,3,4,5) 
); 
echo $ arrl["color"][0], $ arrl["number"][4]; // 输 出 : 红色 5 
print_r( $arrl); 
echo "<br >"; 
$ arr2 =array(array( "红色", "绿色 "," 蓝 色 "),array(1,2,3,4,5)); 
echo $arr2[0][0], $arr2[1][4]; // 输 出 : 红色 5 
print_r( $arr2); 
?> 


程序 解释 : print_r( $ arrl) 语 句 的 运行 结果 为 Array ( [color] = 之 Array ( [0] 三 过 
红色 [1] 一 > 绿色 [2] = 二 蓝 色 ) [number] 一 > Array ( [0] 一 > 1 [1] =>>2[2]=> 
3 [3] =>>4[4] => 5))。 

print_r( $ arr2) 语 句 的 运行 结果 为 Array ( [0] => Array ( [0] = 之 红色 [1] 一 > 绿 
色 [2] 一 > 蓝 色 ) [1] 一 > Array ( [0] 一 > 1 [1] = 一 > 2 [2] => 3 [3] => 4[4] => 5))。 

3. 使 用 变量 名 建立 数组 

通过 使 用 compact() 函 数 ,可 以 把 多 个 变量 ,甚至 数组 紧 姿 成 一 个 数组 ,其 中 ,变量 名 成 
为 数组 元 素 的 键 名 ,变量 值 成 为 数组 元 素 的 值 。 语 法 格式 如 下 : 

数组 名 = compact ("变量 名 ",.…[ "数组 名 "]) 

举例 如 下 : 


<?php 
$ num 











$ str 
$arr = array(2,4,6); 
$newarr = compact("num", "str", "arr"); 


print_r( $ newarr); 
?> 


运行 结果 : 

Array ( [num] =>8 [str] =>abc [arr] =>Array ( [0] =>2[1] =>4[2] =>6)) 

即 数组 $newarr 包含 5 个 元 素 : $newarr[ "num"], $ newarr[ "str"], $newarr 
["arr"][0], $ newarr["arr" J[1], $ newarr[ "arr" J[2]。 

与 compact() 函数 对 应 的 是 extract() 函 数 ,作用 是 将 一 个 数组 分 离 成 多 个 变量 ,语法 格 
式 如 下 : 

extract( 数 组 名 ) 

例如 ， 


<?php 
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$a=array("keyl" =>1,"key2" =>2, "key3" =>3); 
extract( $a); // 数 组 $a 被 分 离 成 $keyl、 $ key2、$ key3 
echo " $ keyl $ key2 $ key3"; 

?> 


注意 : 在 extract( 数 组 名 ) 中 ,数组 的 键 名 必须 是 字母 开头 的 字符 串 。 

4. 建立 指定 范围 的 数组 

使 用 range() 函 数 可 以 建立 一 个 值 在 指定 范围 内 的 数组 ,语法 格式 如 下 : 

数组 名 = range( 初 值 , 终 值 [, 步 长 值 ]) 

注意 : 若 初 值 二 终 值 , 则 步 长 值 为 正 数 ; 若 初 值 二 终 值 , 则 步 长 值 为 负数 。 若 省 略 步 长 
值 , 则 默认 为 1。 例 如 : 


<?php 
$ arrayl = range(1,5); // 输 出 : array( [0] =>1[1] =>2[2] =>3[3] =>4[4] =>5) 
$array2 = range(2,10,2); // 输 出 : Array ( [0] =>2 [1] =>4[2] =>6[3] =>8[4] =>10) 
$array3 = range("a","e"); // 输 出 : Array ( [0] =>a[1] =>b[2] =>c[3] =>d[4] =>e) 
print_r( $ arrayl); 
print_r( $ array2); 
print_r( $ array3); 





?> 
5. 自动 建立 数组 
数组 可 以 不 事先 创建 ,而 是 直接 赋值 ,数组 会 自动 创建 。 例 如 : 
<?php 
$arr[0] = "a"; 
$arr[1] = "b"; 
$arr[2] = "c"; 
print_r( $ arr); // 输 出 : Array ( [0] =>a[1] =>b[2] =>c) 
?> 


说 明 : 在 第 一 个 语句 运行 时 ,如 果 $arr 数组 不 存在 , 则 自动 创建 一 个 只 有 一 个 元 素 的 
$arr 数组 ,后 续 的 语句 将 在 这 个 数组 中 添加 新 值 。 

3.1.2 键 名 和 值 的 操作 

对 于 数组 的 键 名 和 值 .有 不 少 函数 能 操作 它们 。 下 面 介绍 一 些 常 用 函数 。 

1. 存在 性 检查 

(1) array_key_exists() 函数 

格式 : 

array_key_exists( 键 名 ,数组 名 ) 


功能 : 检查 数组 中 是 否 存在 某 个 键 名 , 若 存 在 , 则 返回 true。 
(2) in_array() 图 数 
格式 : 


in_array( 值 ,数组 名 ) 





功能 : 检查 数组 中 是 否 存在 某 个 值 , 若 存在 , 则 返回 true。 
例如 : 
<?php 
$array = array(1,2,3,5=>4,7=>5); 
if (array_key_exists(0, $ array) ) echo "数组 中 存在 键 名 0"; 
if (in_array(5, $ array) ) echo "数组 中 存在 值 5"; 


?> 

2. 获取 和 输出 

(1) array_keys() 函 数 

格式 : 

数组 名 2 = array_keys( 数 组 名 1) 

功能 : 将 数组 1 中 的 所 有 键 名 存 入 数组 2 中 。 


(2) array_values() 函数 
格式 : 


数组 名 2 = array_values( 数 组 名 1) 


功能 : 将 数组 1 中 的 所 有 值 在 人 数组 2 中 。 
例如 


<?php 
$arr=array( "color" => "red","name" =>"Sandy","age" => 20); 
$keys = array_keys( $ arr); 
$ values =array_values( $ arr); 


print_r( $ keys); // 输 出 : Array ( [0] =>color [1] =>name [2] =>age ) 
print_r( $ values); // 输 出 : Array ( [0] => red [1] => Sandy [2] =>20) 

?> 

3. 遍历 数组 

与 数组 的 遍历 有 关 的 函数 有 : 

next( 数 组 名 ) // 把 数组 指针 移 向 下 一 个 元 素 

prev( 数 组 名 ) // 把 数组 指针 移 向 上 一 个 元 素 

reset( 数 组 名 ) // 把 数组 指针 移 到 第 一 个 元 素 

end( 数 组 名 ) // 把 数组 指针 移 到 最 后 一 个 元 素 

key( 数 组 名 ) // 取 数组 当前 元 素 的 键 名 

each( 数 组 名 ) // 取 数组 当前 元 素 的 键 名 和 值 , 并 把 指针 移 向 下 一 个 元 素 

list(varl,var2,...) = arr; // 把 数组 arr 各 值 分 别 赋 给 各 变量 varl, var2, .… 

例如 ， 

<?php 


$ arr =array( "color" =>"red", "name" =>"Sandy", "age" => 20); 
for( $i=0; $i<count( $arr); $i++){ 

echo key( $ arr).","; 

next( $ arr); 
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$arr2 = array("one", "two", "three"); 
list( $vl, $v2, $v3) = $arr2; 
echo "$v1l, $v2, $v3"; 

?> 


运行 结果 : 

color, name, age, one, two, three 

3.1.3 数组 的 排序 

PHP 提供 了 许多 数组 排序 函数 ,使 一 维 数 组 的 排序 变 得 非常 简单 。 

1. 升序 排序 

(1) sort() 函 数 

格式 : 

sort( 数 组 名 ) 

功能 : 对 数组 的 值 进行 升序 排序 ,并 将 数组 的 键 名 修改 为 从 0 开始 的 整数 键 名 。 
(2) asort() 函 数 

格式 : 

asort( 数 组 名 ) 

功能 : 对 数组 的 值 进行 升序 排序 ,但 保持 数组 的 键 名 和 值 之 间 的 关联 。 
例如 : 


<?php 
$arrl = array("a" =>5,"x"=>3,5=>7,"c"=>1); 
$arr2 = array(2=>"c",4=>"a",1=>"b"); 
Sort( $ arr1); 
asort( $ arr2); 


print_r( $arrl); // 输 出 : Array ( [0] =>1[1] =>3 [2] =>5[3] =>7) 
print_r( $arr2); // 输 出 : Array ( [4] =>a[1] =>b[2] =>c) 

?> 

2. 降序 排序 


rsort()、arsort() 分 别 对 应 于 上 面 的 sort() ,asort() 函 数 ,但 是 排序 是 降序 的 。 

3. 对 多 个 数组 同时 排序 

array_multisort() 函 数 可 以 一 次 对 多 个 一 维 数组 排序 。 语 法 格式 如 下 : 

array_multisort( 数 组 名 ,.…, 数 组 名 ) 

功能 : 首先 对 第 一 个 数组 的 值 升序 排列 ,其 他 数组 中 值 的 顺序 按照 第 一 个 数组 的 对 应 
顺序 排列 。 数 组 列表 中 所 有 数组 的 长 度 必须 相等 。 例 如 : 


<?php 
$arl = array(3,5,2,4); 
$ar2 = array(8,6,9,7); 
array_multisort( $arl, $ar2); 


print_r( $arl); // 输 出 : Array ( [0] =>2 [1] =>3 [2] =>4[3] =>5) 
echo "<br />"; 
print_r( $ ar2); // 输 出 : Array ( [0] =>9 [1] =>8 [2] =>7 [3] =>6) 


2 


说 明 : 第 一 个 数组 中 值 的 原先 顺序 是 3,5,2,4, 对 应 的 第 二 个 数组 中 值 的 顺序 是 8,6， 
9,7, 排 序 后 第 一 个 数组 中 的 值 为 2,3,4,5, 第 一 个 元 素 中 的 值 为 2, 对 应 于 第 二 个 数组 中 的 
值 为 9, 因 此 9 成 为 第 二 个 数组 排序 后 的 第 一 个 元 素 , 以 此 类 推 。 

4. 打 乱 数组 的 顺序 

格式 : 


shuffle( 数 组 名 ); 


功能 : 打 乱 数组 的 顺序 ,并 将 数组 的 键 名 修改 为 从 0 开始 的 整数 键 名 。 
【 例 3-1】 产生 10 个 [1,100] 范 围 内 的 互 不 重复 的 随机 整数 。 


<?php 
$arr= range(1,100); 
shuffle( $ arr); 
for( $i=0;$i<10;$ i++) 
{ 
echo $arr[ $i]. ","; 
} 


?> 








5. 按 相反 顺序 排序 
格式 : 
数组 名 2 = array_reverse( 数 组 名 1 [, key]); 


功能 : 将 数组 1 按 相 反 顺 序 排序 ,生成 数组 2。 若 key 取 true, 则 数组 2 保持 原来 的 键 
名 ; 若 key 取 false, 则 数组 2 的 键 名 修改 为 从 0 开始 的 整数 键 名 。key 省 略 时 为 false。 


例如 : 
<?php 
S$array= array("a" =>1,2,3,4); 
$arl = array_reverse( $array); //$ arl 的 键 名 修改 为 从 0 开始 的 整数 键 名 
$ ar2 = array_reverse( $array, true); //$ ar2 保持 原来 的 键 名 
print_r( $arl); // 输 出 : Array([0] =>4 [1] =>3 [2] =>2 [a] =>1) 
print_r( $ar2); // 输 出 : Array([2] =>4 [1] =>3 [0] =>2 [a]=>1) 
?> 


3.2 字符 串 操作 


字符 串 是 很 常用 的 数据 类 型 ,特别 是 网 页 源 代码 本 身 就 是 字符 串 。 因 此 ,字符 串 有 很 多 
操作 函数 。 由 于 PHP 是 弱 语 言 类 型 ,所 以 当 使 用 字符 串 操作 函数 时 ,其 他 类 型 的 数据 也 会 
被 当 作 字 符 串 来 处 理 。 
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3.2.1 常用 的 字符 串 函 数 
1. 计算 字符 审 的 长 度 

格式 1: 

strlen( 字 符 串 ) 


功能 : charset= 二 GB2312, 每 个 汉字 为 2 个 字符 ; charset 二 UTF-8, 每 个 汉字 为 3 个 
字符 。 

格式 2: 

mb_strlen( 字 符 串 ,编码 方式 ) 

功能 : 编码 方式 为 GB2312, 每 个 汉字 为 2 个 字符 ; 编码 方式 为 UTF-8, 每 个 汉字 为 
3 个 字符 。 例 如 ,mb_strlen( 字 符 串 ,"GB2312")。 

2. 改变 字母 大 小 写 


strtolower( 字 符 串 ) // 将 字符 串 转化 为 小 写字 母 
strtoupper( 字 符 串 ) // 将 字符 串 转化 为 大 写字 母 
3. 删除 字符 串 的 首尾 空格 

ltrim( 字 符 串 ) // 删 除 字符 串 首部 空格 
rtrim( 字 符 串 ) // 删 除 字符 串 尾 部 空格 
trim( 字 符 串 ) // 删 除 字符 串 首 、 尾 空格 

4. 字符 串 查找 


用 于 字符 串 查 找 的 函数 非常 多 , 仅 介绍 如 下 两 个 。 


strstr( 串 1， 串 2 [, 是 否 串 2 之 前 ]) 
stristr( 串 1， 串 2 [, 是 否 串 2 之 前 ]) 
功能 : 在 串 1 中 查找 串 2, 如 果 查 找 成 功 , 且 省 略 [是 否 串 2 之 前 ], 则 返回 串 1 中 从 第 一 
次 出 现 串 2 开始 直到 字符 串 结尾 的 字符 串 , 若 [是 否 串 2 之 前 ] 取 true 时 , 则 在 串 1 中 截取 串 2 
之 前 的 那 部 分 子 串 。 如 果 查 找 不 成 功 , 则 返回 false。[ 是 否 串 2 之 前 ] 省 略 时 ,默认 为 false。 
stristr 函数 与 strstr 作用 类 似 , 只 是 不 区 分 大 小 写 。 例 如 : 
<?php 
$str = "hello world"; 
$find = "llo"; 
$resl = strstr( $ str, $ find); 
$res2 = strstr( $ str, $ find, true); 


echo " $ resl, $ res2"; // 输 出 : 1lo world, he 
?> 


5. 截取 子 串 
格式 : 


substr( 字 符 串 ,n, len) 


功能 : 对 字符 串 从 第 n 个 字符 开始 ,截取 len 个 字符 ,形成 子 串 。 

说 明 : 1 个 字母 .数字 为 一 个 字符 ,1 个 汉字 为 2 个 (charset 王 GB2312) 或 3 个 (charset 一 
UTF-8) 字 符 。 

例如 , 当 charset 二 GB2312 时 ,substr(" 汕 头 职 院 ",2,4) = 二" 头 职 "; 当 charset 二 UTF-8， 
substr(" 汕 头 职 院 ",3,6) = 二" 头 职 "。 

6. 字符 串 与 ASCll 码 


格式 : 
ord( 字 符 串 ) // 返 回 字符 串 中 第 一 个 字符 的 ASCII 码 
chr(n) // 返 回 ASCII 码 n 对 应 的 字符 
例如 : 
<?php 
echo ord("a"); // 输 出 97 
echo chr(97); // 输 出 a 
?> 
7. 字符 串 的 比较 


(1) 使 用 关系 运算 符 比 较 

数值 与 字符 串 比 较 , 或 两 个 数字 字符 串 比较 , 先 统一 为 数值 ,再 比较 。 例 如 ,表达 式 
"123. 5" 盖 "9.5" 返 回 true, 即 123.5 大 于 9.5。 

(2) strcmp( 串 1, 串 2): 不 管 字符 串 如 何 , 都 不 会 转换 成 数值 。 

若 串 1 二 串 2, 则 strcmp() 返 回 1; 车 串 1== 串 2, 则 strcmp() 返 回 0; 若 串 1 一 串 2, 则 
strcmp() 返 回 一 1。 例 如 ,strcmp("123. 5","9.5") 返 回 一 1, 即 "123. 5" 小 于 "9.5"。 

8. 字符 串 替 换 

格式 : 

新 串 = str_replace( 子 串 1, 子 串 2, 字 符 串 ) 


功能 : 将 字符 串 中 的 子 串 1 替换 成 子 串 2, 形 成 新 字符 串 。 
例如 : 
<?php 

$str= "Ilove you"; 

$ replace = "lucy"; 

$ end = str_replace( "you", $ replace, $ str); 


echo $ end; // 输 出 : I love lucy 
?> 


3.2.2 字符 串 与 HTML 


1. 将 特殊 字符 转换 为 HTML 代码 
大 多 数字 符 转换 为 HTML 代码 时 仍 保持 不 变 ,但 一 些 特殊 字符 (例如 “二 ”和 “二 ”) 转 
换 为 HTML 代码 时 发 生 了 较 大 的 变化 ,如 表 3-1 所 示 。 
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表 3-1 特殊 字符 和 对 应 的 HTML 代码 




















特殊 字符 字符 名 称 转换 后 的 HTML 代码 
& and 符号 Ramp; 
双 引 号 .quots 
本 单 引号 #039; 
小 于 号 &lt; 
> 大 于 号 Rgt; 











在 PHP 脚本 中 ,htmlspecialchars() 函 数 也 可 将 特殊 字符 转换 为 HTML 代码 ,其 语法 
格式 为 : htmlspecialchars( 字 符 串 ) ,功能 是 : 将 含有 HTML 标记 的 字符 串 编 码 ( 如 “二 ” 编 
为 *&1t;”,“ 二 ” 编 为 *&-gt;”) ,使 浏览 器 能 显示 HTML 标记 本 身 。 例 如 : 


<?php 
$new = '<a href = "test"> test </a>'; 
// 编 码 成 : &lt;a href = gquot; test&quot; ggt; test&lt;/aggt; 
$ str = htmlspecialchars( $ new); 
echo $ str; // 输 出 : <a href = "test"> test </a> 
?> 


2. 将 HTML 代码 转换 为 特殊 字符 
在 PHP 脚本 中 ,htmlspecialchars_decode() 函 数 可 将 字符 串 中 的 HTML 代码 转换 为 
特殊 字符 ,其 语法 格式 为 : htmlspecialchars_decode( 字 符 串 )。 例 如 : 


<?php 
$str = "&lt;a href = &quot;test&quot; &gt; test&lt;/aggt;"; 
// 输 出 : <a href = "test"> test </a> 
echo htmlspecialchars_decode( $ str); 

De 


3.2.3 ”其 他 字符 串 函 数 


1. 字符 串 转化 为 数组 

格式 ; 

数组 名 = explode( 分 隔 符 ,字符 串 ) 

功能 : 使 用 分 隔 符 , 将 字符 串 分 为 若干 个 子 串 ,并存 人 数组 中 。 
例如 : 


<?php 
$ str = "can you help me"; 
$arr = explode(" ", $ str); 
print_r( $ arr); 

?> 


2. 数组 转化 为 字符 串 
格式 : 
字符 串 变量 = implode( 连接 符 ,数组 名 ) 
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功能 : 使 用 连接 符 , 将 数组 中 的 字符 串 连接 成 一 个 字符 串 。 
例如 : 
<?php 
$array = array("hello", "how", "are", "you"); 
$ str = implode(",", $ array); 


echo $ str; // 输 出 : hello, how,are, you 
?> 


3. 字符 串 加 密 函 数 
通过 加 密 算 法 可 将 明文 变 为 密 文 , 达 到 保护 数据 的 安全 性 。PHP 使 用 crypt( ) 函数 完 
成 加 密 功 能 ,语法 格式 如 下 。 
(1) 密 文 三 crypt( 字 符 串 ) 
功能 : 对 指定 字符 串 加 密 ,生成 一 个 新 的 密 文 。 每 次 调用 生成 的 密 文 是 不 同 的 。 
(2) 密 文 一 crypt( 字 符 串 [, 密 文 ]) 
功能 : 对 指定 字符 串 加 密生 成 的 密 文 与 原 给 定 的 密 文 相同 。 
crypt() 函 数 是 单 向 函数 , 密 文 不 可 以 还 原 成 明文 。 例 如 : 
<?php 
$ str = "与 时 俱 进 "; 
$ pass = crypt( $ str); 
echo $ pass."<br>"; 


if (crypt( $ str, $ pass) == $ pass) echo "验证 成 功 !"; 
kb 


3.3 正则 表达 式 


正则 表达 式 是 一 种 模糊 匹配 模式 ,特别 适合 于 模糊 查找 与 蔡 换 。 很 多 高 级 语言 都 逐渐 
支持 正则 表达 式 。 正 则 表达 式 在 历史 上 出 现 过 两 种 比较 流行 的 语法 : POSIX 和 Perl, 但 是 
由 于 Perl 的 效率 更 高 ,因此 PHP 自 5. 3. 0 起 仅 支持 Perl 兼容 的 正则 表达 式 。 


3.3.1 基础 知识 


正则 表达 式 是 由 普通 字符 (如 字符 a 一 z) 和 特殊 字符 组 成 的 字符 串 模式 。 该 模式 设 定 
了 一 些 规 则 , 当 正则 表达 式 函 数 使 用 这 些 规则 时 ,可 以 根据 设 定好 的 内 容 对 指定 的 字符 串 进 
行 匹配 。 

使 用 正则 表达 式 可 以 完成 以 下 功能 。 

(1) 测试 字符 串 的 某 个 模式 。 例 如 ,可 以 对 一 个 输入 字符 串 进行 测试 ,看 在 该 字符 串 中 
是 否 存在 一 个 E-mail 地 址 模式 或 一 个 身份 证 模式 ,这 称 为 数据 有 效 性 验证 。 

(2) 替换 文本 。 可 以 在 文档 中 使 用 一 个 正则 表达 式 来 标志 特定 字符 串 , 然 后 全 部 将 其 
删除 ,或 者 蔡 换 为 别 的 字符 串 。 

(3) 根据 模式 匹配 从 字符 串 中 提取 一 个 子 字符 串 。 可 以 用 来 在 文本 或 输入 字段 中 查找 
特定 字符 串 。 

正则 表达 式 是 由 普通 字符 .特殊 字符 组 成 的 一 种 字符 模式 , 它 由 两 个 斜 杠 (/) 括 住 。 正 
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则 表达 式 的 特殊 字符 见 表 3-2。 
表 3-2 正则 表达 式 的 特殊 字符 





















































特殊 字符 说 明 示 例 

? 表示 前 面 的 字符 有 0 个 或 1 个 /ab? /表示 a\ab 

关 表示 前 面 的 字符 有 0 个 或 多 个 /ab * /表示 a、ab、abb、abbb 等 

于 表示 前 面 的 字符 有 1 个 或 多 个 /ab 十 /表示 ab、abb、abbb 等 

/(ab) 十 /表示 ab、abab、ababab 等 

有 3 种 方式 : {n) 表示 前 面 的 字符 有 | /abc(3)/ 表 示 abece 

{} n 个 ; {n,) 表 示 前 面 的 字符 大 于 等 于 | /(abc){3)/ 表 示 abcabcabc 
n 个 ; (m,n) 表示 前 面 的 字符 有 m~n 个 | /ab(3,5)/ 表 示 abbb .abbbb .abbbbb 

[] 表示 [ ] 内 的 任 一 个 字符 he /[ab 一 ]/ 表 示 
表示 一 个 任意 字符 /.15,10}/ 表 示 5~10 个 任意 字符 

Cy 选择 性 的 符号 ,可 用 可 不 用 ,只 是 为 了 
增加 可 读 性 

| 表示 “或 ” 
若 用 户 输入 的 数据 包含 特殊 符号 (如 () , 三 

\ CIO 1 ), 则 必须 在 特殊 符号 前 加 上 | fo 0 下 全 国人 的 和 
符号 ,如 \C\) 

y 匹配 字符 串 的 开始 位 置 /he/ 表 示 以 "he ' 开 头 的 字符 串 

$ 匹配 字符 串 的 结束 位 置 /he$ /表示 以 'he' 结 尾 的 字符 串 

\d 表示 0 一 9 中 的 一 个 数字 与 /[0-9]/ 相 同 

\s 匹配 任何 空白 字符 ,包括 空格 、 制 表 符 、 
换 页 符 等 

如 表示 任意 一 个 大 写字 母 .小 写字 母 或 与 /[azA-Z0-9]/ 相 同 
数字 

注意 : 


(1) 在 [ ] 中 , 若 “-" 位 于 两 个 字符 之 间 , 则 “-" 作 为 特殊 字符 解释 。 例 如 ,[a-z] 表 示 任意 
一 个 小 写字 母 。 

(2) 在 { } 中 的 “,” 作 为 特殊 字符 解释 。 例 如 ,.{15,10} 表 示 5 一 10 个 任意 字符 。 

以 下 是 几 个 实用 的 正则 表达 式 的 例子 。 

身份 证 号 码 由 18 位 数字 或 17 位 数字 后 加 一 个 X 或 立 组 成 ,因此 ,身份 证 号 码 的 正则 
表达 式 为 : / [0-9]{17}[0-9XY] /。 邮 政 编码 由 6 位 数字 组 成 ,因此 ,邮政 编码 的 正则 表达 
式 为 : / [0-9]{6})/。 

E-mail 地 址 的 正则 表达 式 可 以 这 样 写 ， 

/[a-zA-20-9\-]+@[a-zA-20-9_]+\.[a-zA-20-9\.]+/ 


其 中 , 子 表达 式 [a-zA-Z0-9_\-] 十 匹配 E-mail 用 户 名 ,由 字母 ,数字 、 下 夯 线 和 “-" 组 成 ; 子 表 
达 式 [a-zA-Z0-9_] 十 匹配 主机 的 域名 ,由 字母 .数字 和 下 夯 线 组 成 ;“\. ”匹配 点 号 (. ); 子 表 
达 式 [a-zA-Z0-9、\. ] 十 匹配 域名 的 剩余 部 分 ,由 字母 .数字 和 下 夯 线 组 成 。 
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3.3.2 正则 表达 式 在 JavaScript 中 的 应 用 


test() 是 JavaScript 提供 的 最 重要 的 正则 表达 式 函 数 ,用 于 验证 用 户 输入 的 数据 是 否 满 
足 指 定 的 格式 ,语法 格式 如 下 : 

正则 表达 式 . test( 字 符 串 ) 

说 明 : 在 字符 串 中 查找 与 正则 表达 式 相 匹配 的 内 容 , 若 找到 , 则 返回 true; 否则 返回 
false。 若 正则 表达 式 未 含 “”“ $ ”, 只 要 正则 表达 式 为 字符 串 的 子 串 , 该 函数 就 返回 true。 
若 正 则 表达 式 包含 “*” $”, 只 有 正则 表达 式 与 字符 串 完全 匹配 ,该 函数 才 返 回 true。 

【 例 3-2】 test 的 用 法 示例 。 

< script language = "javascript"> 


var a=/\d{6}/; 
var b=/^\d{6} $/; 








document. write(a. test("12345678")); // 返 回 true 
document. write(b. test("12345678")); // 返 回 false 
</script > 


3.3.3 正则 表达 式 在 PHP 中 的 应 用 

在 PHP 中 ,正则 表达 式 最 好 放 在 单 引 号 中 ,使 用 双 引 号 会 带 来 一 些 不 必要 的 复杂 性 。 

1. 字符 串 匹配 

格式 : 

preg_match( 正则 表达 式 , 字符 串 ) 

功能 : 在 字符 串 中 查找 与 正则 表达 式 相 匹配 的 内 容 ,车 找到 , 则 返回 1; 否则 返回 0。 

车 正 则 表达 式 未 含 “*”“$”, 只 要 正则 表达 式 为 字符 串 的 子 串 ,该 函数 就 返回 1。 若 正 
则 表达 式 包含 “*”$”, 只 有 正则 表达 式 与 字符 串 完 全 匹配 ,该 函数 才 返 回 1。 

【 例 3-3〗】 preg_match 的 用 法 示例 。 


<?php 
$ str = "PHP is so easy"; 
// 模 式 定 界 符 后 面 的 i 表示 不 区 分 大 小 写 的 搜索 
$a = preg_match( '/php/i', $ str); 
$b = preg_match( '/*php$ /i', $ str); 





echo $a; // 输 出 : 1 
echo $b; // 输 出 : 0 
?> 
2. 字符 串 蔡 换 
格式 : 


preg_replace( 正则 表达 式 , 替换 串 ,字符 串 ) 


功能 : 在 字符 串 中 查找 正则 表达 式 相 匹配 的 内 容 , 若 找到 , 则 将 匹配 项 蔡 换 为 蔡 换 串 。 
例如 : 
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3. 字符 串 的 分 割 

格式 : 

数组 名 = preg_split( 正 则 表达 式 ,字符 串 ) 

功能 : 以 正则 表达 式 指 定 的 内 容 作为 分 隔 符 , 将 字符 串 分 隔 为 若干 子 串 ,并存 和 人数 组 中 。 
例如 : 


<?php 

$str = "good night, friend"; 

$pattern = '/[\s,] +/°; 

$words = preg_split( $ pattern, $ str); 

print_r( $ words); 

// 输 出 : Array ( [0] => good [1] =>night [2] => friend ) 
?> 


4. 返回 匹配 的 数组 元 素 

格式 : 

数组 名 2 = preg_grep( 正 则 表达 式 , 数组 名 1) 

功能 : 在 数组 1 中 查找 包含 正则 表达 式 的 元 素 , 若 找到 , 则 存 和 人 数组 2 中 。 
<?php 


$array = array("name", "number", "project", "input" ); 
$a= preg_grep( '/*n/', $ array); 


print_r( $a); // 输 出 Array([0] => name [1] =>number) 

$b=preg grep("/e+/", $array); 

print_r( $ b); // 输 出 Array([0] =>name [1] =>number [2] => project ) 
?> 


【 例 3-4】 在 EX3-4a. php 中 制作 如 图 3-1 所 示 的 表单 。 使 用 正则 表达 式 验 证 用 户 输入 
的 数据 是 否 满足 如 下 要 求 : 用 户 名 不 得 超过 10 个 字符 (字母 或 数字 ) ; 密码 必须 为 4 一 14 个 
数字 ; 手机 号 码 必须 为 11 位 数字 , 且 第 1 位 为 1; 邮箱 必须 为 有 效 的 邮箱 地 址 。 当 单 击 “ 注 
册 ” 按 钮 后 , 若 用 户 未 输入 或 输入 错误 , 则 会 在 相应 控件 的 右边 显示 提示 信息 ,和 否则 ,会 跳 转 
到 EX3-4b. php 页 面 。 











用 记名 [网 
但 码 网 
手机 S 码 一 岗 
邮箱 [网 
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在 EX3-4b. php 页 面 中 ,将 用 户 输 入 的 信息 以 表格 形式 显示 出 来 。 
新 建 EX3-4a. php 页 面 ,输入 以 下 代码 。 


<! DOCTYPE html > 
<html> 
<head> 
<meta http — equiv = "Content - Type" content = "text/html; charset = utf - 8" /> 
</head > 
<body> 
<?php 
if (isset( $ _REQUEST[ "button"])) 


{ 


} 


?> 


$ test=1; 

$ id= $ _REQUEST["ID"]; 

$ pwd = $ _REQUEST[ "PWD" ] ; 

$ phone = $ _REQUEST[ "PHONE" ]; 

$ Email = $ _REQUEST[ "EMAIL" ]; 

if ($id=='') {$ idl=" 用 户 名 不 能 为 空 "; $ test = 0;} 

elseif (preg_match( '/^\w{1,10} $/', $ id) ==0) {$ idl=" 用 户 名 不 超过 10 个 字符 (字母 、 
数字 )"; $ test = 0;} 

if ($ pwd=='') {$ pwdl= "密码 不 能 为 空 "; $ test = 0;} 

elseif (preg_match( '/^\d{4,14} $/', $ pnd) == 0) { $ pwdl = "密码 只 能 为 4~14 个 数字 "; 
$ test = 0;} 

if ( $ phone == ''){ $ phonel = "手机 号 码 不 能 为 空 "; $ test = 0;} 

elseif (preg_match( '/^1\d{10} $ /', $ phone) == 0) { $ phonel = "手机 号 码 必须 为 11 位 , 且 
第 1 位 为 1"; $ test= 0;} 

if ($ Email=='') {$ Emaill = "Email 不 能 为 空 "; $ test = 0;} 

elseif (preg match( '/*[a-zA—-20-9\-]+@[a-zA-20-9_]+\.[a-zA-20-9\.]+$/, 
$ Email) == 0) { $ Emaill = "邮箱 地 址 无 效 "; $ test = 0;} 

if ( $ test == 1) header("Location: EX3 - 4b. php? id= $ idgpwd = $ pwd&phone = $ phone&Email = 
$ Email"); 





< form id= "forml" name = "form1”method = "post" action= ""> 
<table width = "500" border = "1" align= "center" cellpadding = "0"> 


<tr> 
<td height = "30" colspan= "2" align= "center"> 新 用 户 注册 </td> 
</tr> 
<tr> 
<td width = "100" height = "30" align = "center"> 用 户 名 </td> 
<td height = "30">< input type = "text" name = "ID" id = "ID" /><?php echo @ $ idl;?> 
</td> 
</tr> 
<tr> 
<td width = "100" height = "30" align = "center"> 密 码 </td> 
<td height ="30">< input type = " password" name = "PWD" id = "PWD" /> <? php echo @ 
$ pwdl;?></td> 
</tr> 
<tr> 
<td width= "100" height = "30" align = "center"> 手 机 号 码 </td> 
< td height = "30">< input type = "text" name = "PHONE" id = "PHONE" /> <? php echo @ 


第 3 章 ”PHP 数 组 与 字符 


$ phonel;?></td> 


</tr> 
<tr> 
<td width 











"100" height = "30" align = "center"> 邮 箱 </td> 








<td height = "30">< input type = "text" name = "EMAIL" id = "EMAIL" /><?php echo @ 
$ Email1;?></td> 


</tr> 
<tr> 


<td height = "30" colspan = "2" align = "center">< input type = "submit" name = "button" 


id= "button”value = "注册 " /> gnbsp; < input type = "reset" name 


"button2" value = " 重 置 " /></td> 


</tr> 
</table> 
</form> 
</body > 
</html > 


新 建 EX3-4b. php 页 面 , 输 入 以 下 代码 。 


<! DOCTYPE html > 
<html> 
<head> 


<meta http - equiv = "Content - Type" content = "text/html; charset = utf - 8" /> 


</head> 
<body> 
<?php 


$id= $ _REQUEST["id" ]; 


$ pwd= $ _REQUEST[" 


pwd" ]; 


$ phone = $ _REQUEST[ "phone" ]; 
$ Email = $ _REQUEST[ "Email" ]; 


?> 


<table width= "400" border = "1" align= "center" cellpadding = "0"> 















<tr> 
<td width= "150" 
<td width= "250" 
</tr> 
<tr> 
<td width= "150" 
<td width= "250" 
</tr> 
<tr> 
<td width= "150" 
<td width= "250" 
</tr> 
<tr> 


<td width= "150" 
<td width= "250" 
</tr> 
</table> 
</body> 
</html > 


height = "30" align = "center"> 用 户 名 </td> 
height = "30"><?php echo $ id;?></td> 


height = "30" align = "center"> 密 码 </td> 
height = "30"><?php echo $ pnd;?></td> 


height = "30" align = "center"> 手 机 号 码 </td> 
height = "30"><?php echo $ phone;?></td> 


height = "30" align = "center"> 邮 箱 </td> 
height = "30"><?php echo $ Email;?></td> 


"button2" id = 





3.4 项 目 实 训 


实 训 1 数组 和 循环 谋 套 


实 训 目的 

(1) 掌握 二 维 数组 的 定义 与 二 维 数组 元 素 的 表示 。 

(2) 掌握 用 表格 形式 显示 二 维 数组 元 素 的 方法 。 

实 训 要 求 

新 建 一 个 网 页 sx3-1. php, 先 在 其 中 定义 一 个 二 维 数组 如 下 : 


$ course = array( 





ra — 

array( "语文 ", "英语 "," 数 学", "英语 ", "语文 ")， 

array(" 体 育 ", "语文 ", "音乐 ", "数学 ", "政治 ")， 

array(" 数 学 ", "美术 ", "语文 ", "体育 ", "数学 ") 
二 


然后 用 二 维 数组 元 素 制作 一 个 功课 表 表 格 来 。 效 果 如 图 3-2 所 示 。 





| = 到 呈 
| 语文 | 黄 计 | 数字 | 英语 | 语文 
体育 | 语文 | 音乐 | 数学 | 政治 
要 学 | 美玉 | 语文 | 体育 | 表 字 





图 3-2 功课 表 效 果 


实 训 2 正则 表达 式 的 应 用 


实 训 目 的 

(1) 学 会 正则 表达 式 的 编写 。 

(2) 掌握 若干 与 正则 表达 式 有 关 的 函数 。 

实 训 要 求 

新 建 一 个 网 页 sx3-2. php, 让 用 户 输入 留言 ,为 了 避免 用 户 泄露 个 人 信息 ,程序 对 所 输 
入 的 留言 信息 中 的 所 有 数字 都 替换 为 ”*** ”。 数字 包 括 阿 拉 伯 数字 及 中 文 数字 ,以 及 小 数 
点 。 当 用 户 单 击 “ 提 交 ” 按 钮 后 ,在 网 页 下 部 显示 出 过 滤 之 后 的 效果 ,如 图 3-3 所 示 。 

输入 你 的 留言 

en 身高 175 厘 米 ， 体 重 69.5 公 斤 ， 寺 














你 的 留言 是 : 
这 是 我 的 QQ 号 ***， 身 高 *** 厘 米 ， 体 重 *** 公 斤 ， 年 瀹 *** 岁 。 


图 3-3 过滤 网 页 中 的 数字 (包括 中 文 的 数字 ) 信 息 
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思考 与 练习 


一 、 填 空 题 


1. 腾讯 QQ 号 是 从 10000 开始 的 整数 ,那么 ,QQ 号 的 正则 表达 式 是 。 

2. 身份 证 号 码 由 18 位 数字 或 17 位 数字 后 加 一 个 X 或 Y 组 成 ,那么 ,身份 证 号 码 的 正 
则 表达 式 是 

3. PHP 中 数组 的 键 名 (可 以 /不 可 以 ) 重 复 , 值 (可 以 /不 可 以 ) 重 复 ， 
默认 的 数字 键 名 从 开始 。 


二 、 简 答 题 

1. 已 知 二 维 数组 : 

$a=array( array(" 红 色 ", "绿色 "," 蓝 色 "),array(2,4,6,8) ); 

先 请 写 出 它 的 全 部 元 素 和 相应 的 值 ,然后 用 print_r() 函 数 上 机 验证 。 
2. 试 将 下 列 2 个 数组 分 离 成 多 个 变量 ,并 输出 各 变量 的 值 。 


$x=array("keyl" =>1,"key2" =>2,"key3" =>3); 
$y=array("red", "blue", "white", "yellow"); 











3. 现 有 变量 : $a=5, $b==3, $c 二 100, $d==1, $e 二 12, $f==200, 利 用 数组 将 它们 
升序 输出 。 


PHP 从 PHP4 就 引进 了 面向 对 象 的 程序 设计 ,但 其 语言 模型 并 不 完善 , 析 构 函数 .抽象 
类 (接口 )、 异 常 处 理 对 象 等 功能 的 缺乏 , 极 大 地 限制 了 PHP 开发 大 规模 应 用 程序 的 能 力 。 
而 到 了 PHP5,PHP 的 语法 设计 得 到 了 改进 ,终于 使 PHP 成 为 设计 完备 真正 具有 面向 对 
象 能 力 的 脚本 语言 。 


四 ooee 


。 掌握 类 的 定义 和 类 的 成 员 。 

。 掌握 构造 函数 和 析 构 函数 的 定义 和 使 用 。 
。 掌握 对 象 的 创建 和 使 用 。 

。 理解 子 类 的 创建 。 

。 熟练 掌握 方法 的 重 载 。 

。 掌握 接口 的 定义 和 使 用 。 

了 解 接 口 和 抽象 类 的 异同 点 。 


4.1 基本 概念 


常用 的 程序 设计 方法 有 : 结构 化 程序 设计 、 面 向 对 象 程序 设计 。 在 结构 化 程序 设计 中 ， 
数据 和 处 理 数据 的 程序 是 分 离 的 , 当 对 某 段 程序 进行 修改 或 删除 时 ,整个 程序 中 所 有 与 其 相 
关 的 部 分 都 要 进行 相应 的 修改 ,导致 程序 代码 的 维护 比较 困难 。 为 了 避免 这 种 情况 的 发 生 ， 
PHP 引进 了 面向 对 象 的 程序 设计 . 它 将 数据 及 处 理 数据 的 相应 函数 “封装 ”到 一 个 “类 ”中 ， 
类 的 实例 称 为 对象” 。 在 一 个 对 象 内 ,只 有 属于 该 对 象 的 函数 才 可 以 存 取 该 对 象 的 数据 。 
这 样 ,其 他 函数 就 不 会 无 意 中 破 坏 它 的 内 容 , 从 而 达到 保护 和 隐藏 数据 的 效果 。 

面向 对 象 程序 设计 有 两 个 主要 特征 : 封装 、 继 承 。 

1. 封装 

封装 是 指 将 数据 和 实现 操作 的 代码 捆绑 在 一 起 ,避免 外 界 的 干扰 和 不 确定 性 。 封 装 是 
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通过 类 来 实现 的 ,类 是 对 具有 相同 数据 和 相同 操作 的 一 组 相似 对 象 的 定义 ,也 就 是 说 ,类 是 
对 具有 相同 属性 和 行为 的 一 组 对 象 的 描述 ,而 对 象 是 类 的 具体 表现 。 
2. 继承 
一 个 新 类 可 以 继承 已 定义 的 类 ,这 时 ,新 类 称 为 子 类 ,已 定义 的 类 称 为 父 类 。 子 类 继承 
父 类 , 除 继承 父 类 的 所 有 属性 和 行为 外 ,还 可 以 自己 定义 新 的 属性 和 行为 。 


4.2 类 与 对 象 


4.2.1 创建 类 


类 是 面向 对 象 程序 设计 的 核心 ,类 由 属性 和 行为 组 成 ,在 类 中 ,属性 又 称 成 员 变量 ,行为 
又 称 成 员 函 数 或 方法 。 声 明 类 的 语法 格式 如 下 : 
[abstract][final] class 类 名 
{ 成 员 变 量 定义 ; 
成 员 函 数 定义 ; 
} 
下 列 代码 演示 了 类 的 声明 。 
class A 
{ 
public $a; 
protected $ b; 
private $c; 
function setA() 
{ 
$ this->a=1; 
$ this—->b=2; 
$ this—->c=3; 


} 

4.2.2 类 的 属性 和 方法 

类 的 成 员 有 两 类 : 成 员 变量 和 成 员 函 数 。 
成 员 变 量 又 称 属性 ,其 声明 格式 如 下 : 
var/public/protected/private [static] 变量 名 ; 


注意 : var、public 都 表示 公有 属性 ; static 的 前 面 只 能 使 用 public、protected 或 Private 
不 能 使 用 var。 
成 员 函 数 又 称 方法 ,其 声明 格式 如 下 : 


[public/protected/private][static] function 函数 名 ( 形 参 表 ) 
{ } 
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类 成 员 的 访问 权限 有 3 种 ,说 明 如 下 。 

(1) private: 私有 成 员 ,只 能 被 自身 类 的 成 员 函 数 访问 。 

(2) protected: 受 保护 成 员 , 只 能 被 自身 类 和 派生 类 的 成 员 函 数 访问 。 

(3) public: 公有 成 员 , 可 以 被 任意 类 的 成 员 函 数 或 类 外 访问 ,默认 为 public。 

在 进行 类 设计 时 ,通常 将 类 的 属性 设置 为 私有 的 ,而 将 方法 设置 为 公有 的 。 这 样 ,类 以 
外 的 代码 不 能 直接 访问 类 的 私有 数据 ,从 而 实现 了 数据 的 封装 。 而 公有 的 方法 可 为 内 部 的 
私有 数据 提供 外 部 接口 。 


4.2.3 构造 困 数 和 桥 构 函数 


PHP 有 两 个 特殊 的 函数 : 构造 函数 和 析 构 函数 ,分 别 用 于 创建 和 回收 对 象 。 构 造 函 数 
是 当 类 被 实例 化 时 首先 执行 的 函数 ; 析 构 函数 是 当 实例 对 象 从 内 存 删 除 时 执行 的 函数 。 在 
一 个 对 象 的 生命 周期 中 ,都 会 执行 构造 函数 和 析 构 函数 。 下 面 分 别 介 绍 构造 函数 和 析 构 函 
数 的 定义 和 使 用 方法 。 

1. 构造 函数 

构造 函数 的 声明 格式 如 下 : 

[public] function __construct( 形 参 表 ) 

{ 函数 体 } 

注意 : 

(1) 构造 函数 名 为 __construct。 

(2) 一 个 类 最 多 只 能 定义 一 个 构造 函数 ,构造 函数 可 带 形 参 ,也 可 不 带 形 参 。 

(3) 构造 函数 在 创建 对 象 时 被 自动 调用 。 

2. 析 构 函数 

[public] function __destruct() 

{ 函数 体 } 

注意 : 

(1) 析 构 函数 名 为 __ destruct。 

(2) 一 个 类 最 多 只 能 有 一 个 析 构 函数 , 析 构 函数 不 带 形 参 。 

(3) 析 构 函数 在 释放 对 象 时 被 自动 调用 。 

【 例 4-1】 构造 函数 和 析 构 函数 的 用 法 示例 。 


<?php 
class Con 
function __construct( $ num) 
: echo "执行 构造 函数 $ num" ; 
die __destruct() 
echo "执行 析 构 函数 "; 
. 
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} 

$a=new Con( 1'); // 创 建 对 象 $a 

$b=new Con( 2'); // 创 建 对 象 $b 
?> 


程序 解释 : 运行 结果 为 “执行 构造 函数 1 一 执行 构造 函数 2 一 执行 析 构 函数 一 执行 析 构 
函数 ”, 因 为 程序 执行 完毕 时 ,要 释放 对 象 $a、$b, 所 以 会 自动 调用 两 次 析 构 函数 。 


4.2.4 创建 对 象 


类 只 存在 于 文件 中 ,程序 不 能 直接 调用 ,需要 创建 一 个 对 象 后 程序 才能 调用 ,创建 一 个 
类 对 象 的 过 程 叫 作 类 的 实例 化 。 
1. 创建 对 象 
格式 1: 
对 象 名 = new 类 各 ; 
格式 2: 
对 象 名 = new 类 名 ( 实 参 表 ); 
注意 : 
(1) 格式 1 用 于 指定 类 中 未 包含 构造 函数 或 包含 无 参 构 造 函 数 ; 格式 2 用 于 指定 类 中 
包含 带 参 构造 函数 。 
(2) 先 创 建 一 个 类 ,然后 在 类 的 外 面 创建 该 类 的 对 象 。 
(3) 创建 对 象 ,意味 着 为 对 象 或 类 的 公有 属性 开辟 存储 单元 。 
【 例 4-2】 对 象 的 创建 示例 。 
<?php 
class 及 
{ 
public $ a; 
protected $ b; 
private $c; 


function setA() 


{ 





$ this—->a=1; 

$ this—->b=2; 

$ this—->c=3; 

} 

} 
$ obj = new A; 
$ obj -> setA(); 
echo $ obj ->a; // 在 类 外 只 能 访问 公有 成 员 


?> 


2. 非 静态 成 员 与 静态 成 员 


非 静 态 成 员 属 于 某 个 对 象 ,不 同 的 对 象 有 各 自 的 非 静 态 成 员 , 所 以 非 静 态 成 员 的 引用 格 
式 如 下 : 
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$ this -> 非 静 态 成 员 (在 类 内 引用 , 属性 名 前 面 要 省 略 $ ) 
对 象 名 -> 非 静 态 成 员 “(在 类 外 引用 ,属性 名 前 面 要 省 略 $ ) 

静态 成 员 属 于 整个 类 ,被 该 类 的 所 有 对 象 共享 ,所 以 静态 成 员 的 引用 格式 如 下 : 
类 名 : :静态 成 员 (在 类 内 与 类 外 引用 ,属性 名 前 面 有 $ ) 

注意 ， 

(1)“::” 称 为 范围 解析 符 , 访 问 静 态 属 性 和 静态 方法 需要 使 用 范围 解析 符 。 
(2) $ this 不 能 出 现在 静态 方法 中 。 

【 例 4-3】 非 静 态 成 员 与 静态 成 员 的 比较 示例 。 


<?php 
1 class Student 
2 { 
3 var $a; 
4 static $b; 
5 function __construct() 
6 { 
7 $ this—->a=20; 
8 Student: : $ b= 200; 
9 } 
10 |} 


11 $ stul = new Student( ); 

设 $ stu2 = new Student( ); 

13 $stul->a=10; 

14 Student:: $b=100; 

15 echo '$ stu2->a='. $stu2->a.'<br>'; 
16 echo 'Student::$ b= "'.Student::$b; 


程序 说 明 : 第 11 行 和 第 12 行 创建 了 两 个 对 象 , 即 $ stul 和 $ stu2, 它 们 有 各 自 的 $a 
属性 值 ,但 $b 属性 值 为 两 个 对 象 共享 ,所 以 程序 运行 结果 是 : 


$ stu2->a=20 
Student:: $b=100 


4.3 类 的 继承 


4.3.1 子 类 的 创建 


PHP 只 支持 单 继承 , 即 一 个 子 类 只 能 有 一 个 父 类 。 子 类 可 以 继承 父 类 的 非 私有 属性 和 
非 私 有 方法 (包括 继承 父 类 的 构造 函数 和 析 构 函数 ), 还 可 以 定义 自己 的 新 成 员 。 

继承 性 使 软件 模块 可 以 最 大 限度 地 复 用 ,并 且 编 程 人 员 还 可 以 对 他 人 或 自己 以 前 的 模 
块 进行 扩充 ,而 不 需要 修改 原来 的 源 代码 ,大 大 提高 了 软件 的 开发 效率 。 

继承 的 语法 如 下 : 


class 子 类 extends 父 类 
{ 类 的 属性 和 方法 定义 } 
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【 例 4-4】 子 类 继承 父 类 的 示例 。 


<?php 
1 classA 
2 { 
3 public $a; 
4 Protected static $ b="string2 "; 
EF private $c= "string3 "; 
6 function __construct() 
7 f 
8 $ this—->a= "stringl "; 
9 } 
10 public functiona_fun() 
3 { 
12 $this 一 >a="string4 "; 
13 } 
14 } 
15 classB extends A 
16 { 
17 public $ x; 
18 public function b_fun() 
19 { 
20 //parent::a_fun( ); 
21 $ this—->a_fun(); 
22 echo $ this ->a; 
23 echo B:: $b; 
24 } 
25 } 


26 $0obj= new B; 
27 echo $ obj—->a; 
28 $0obj->b_fun(); 


程序 说 明 : 子 类 B 共 有 3 个 属性 : $a、$b、$x, 以 及 3 个 方法 : __construct() ,a_fun()、 
b_fun()。 第 26 行 创建 对 象 $ obj ,意味 着 为 $obj 一 >a.$obj 一 之 x 开 辟 存 储 单元 ,程序 的 
运行 结果 为 : 

stringl string4 string2 

在 子 类 中 ,引用 从 父 类 继承 下 来 的 成 员 与 引用 自己 定义 的 成 员 ,语法 是 一 致 的 。 但 引用 
父 类 的 方法 还 可 使 用 parent: : 父 类 方法 ,如 第 20 行 和 第 21 行 效果 是 相同 的 。 


4.3.2 方法 覆盖 


在 一 个 类 中 ,可 以 定义 多 个 名 称 相同 的 方法 ,但 形 参 个 数 或 形 参 类 型 有 所 不 同 , 则 这 多 
个 方法 互 为 重 载 。PHP 目前 不 支持 方法 的 重 载 , 即 在 一 个 类 中 不 允许 定义 多 个 名 称 相同 的 
方法 。 

方法 的 覆盖 是 指 在 父 类 和 子 类 中 ,分 别 定义 声明 部 分 完全 相同 的 方法 , 则 称 子 类 的 方法 
覆盖 父 类 的 方法 。PHP 支持 方法 的 覆盖 ,在 PHP 中 ,只 要 子 类 定义 的 方法 与 父 类 中 的 方法 名 
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称 相同 ,不 管 形 参 是 否 相同 ,都 称 子 类 的 方法 覆盖 父 类 的 方法 。 此 时 , 父 类 的 方法 隐藏 起 来 。 
【 例 4-5】 方法 覆盖 的 示例 。 


<?php 

class 及 
public $ x= "stringA"; 
function func( $a) 
{ 

echo " 父 类 A"; 

} 

} 


class B extends A 
{ 
public $ x= "stringB"; 
function func() 
{ 
echo " 子 类 B"; 
? 
} 
$b=newB(); 
echo $b->x; 
$b->func(); 
?> 
程序 说 明 : 在 类 B 中 ,类 B 的 属性 $x 和 方法 func() 分 别 覆 盖 了 类 A 的 $x 和 func()， 
所 以 ,类 B 只 有 一 个 属性 $x 和 一 个 方法 func()。 


4.4 抽象 类 与 接口 


4.4.1 抽象 类 

1. 抽象 方法 

抽象 方法 只 提供 方法 的 声明 ,不 提供 方法 的 具体 实现 。 即 抽象 方法 的 语法 格式 如 下 : 
abstract function 隐 数 名 ( 形 参 表 ); 


2. 抽象 类 示例 

用 abstract 修饰 的 类 称 为 抽象 类 。 只 要 类 中 有 一 个 方法 被 声明 为 abstract, 则 该 类 必须 
为 抽象 类 ,抽象 类 具有 如 下 特性 。 

(1) 一 个 抽象 类 一 般 包 含 一 个 或 多 个 抽象 方法 。 

(2) 抽象 类 只 能 用 来 派生 子 类 ,不 能 创建 对 象 。 

(3) 当 子 类 继承 一 个 抽象 类 时 , 子 类 必须 给 出 父 类 抽象 方法 的 具体 实现 。 

【 例 4-6】 抽象 类 的 示例 。 


<?php 
// 定 义 抽象 类 teacher 
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abstract class teacher 
{ 
var $ number = "101"; 
var $ project; 
abstract function shownumber( ); 
abstract function getproject( $ x); 
function showproject() 
上 
echo $ this—>project; 
} 
} 
// 定 义 子 类 stu 
class stu extends teacher 
{ 
function shownumber() 
{ 
echo $ this— > number; 
} 
function getproject( $ x) 
{ 
$ this—>project = $ x; 
} 
} 
$ obj = new stu; 
$ obj - > shownumber( ); 
$obj ->getproject(" 计 算 机 "); 
$ obj - > showproject(); 


3 
4.4.2 接口 
1. 接口 的 定义 


PHP 只 能 进行 单 继承 , 即 一 个 类 只 能 有 一 个 父 类 。 为 了 解决 这 个 问题 ,PHP5 引入 了 
接口 的 概念 ,接口 是 一 个 特殊 的 抽象 类 。 接 口中 声明 的 方法 都 是 抽象 方法 ,接口 中 不 能 使 用 
属性 ,但 可 以 使 用 const 关键 字 定 义 的 常量 。 接 口 的 定义 格式 如 下 : 

interface 接口 名 

{ const 符号 常量 = 初 值 ; 

function 函数 名 ( 形 参 表 ) ; 

} 

注意 : 

(1) 接口 类 似 于 抽象 类 ,接口 中 的 所 有 方法 都 是 抽象 方法 。 

(2) 在 接口 定义 中 ,必须 省 略 关键 字 abstract。 

(3) 在 抽象 方法 定义 中 ,必须 省 略 关键 字 abstract。 

2. 接口 的 实现 

定义 了 接口 之 后 可 以 将 其 实例 化 ,接口 的 实例 化 称 为 接口 的 实现 。 要 实现 一 个 接口 需 
要 一 个 子 类 来 实现 接口 的 所 有 抽象 方法 ,一 个 子 类 在 继承 一 个 父 类 的 同时 ,可 以 实现 多 个 接 


口 , 这 样 就 解决 了 多 继承 的 问题 。 接 口 的 实现 格式 如 下 : 


class 类 名 implements 接口 名 表 
{ } 


【 例 4-7】 接口 的 定义 和 实现 示例 。 


<?php 
interface Teacher 
{ 
const name = ""; 
function getname( $ name); 
} 
interface Stu 
{ 
function showname() ; 
} 
class Cstu implements Teacher, Stu 
{ 
var $ name= ""; 
function getname( $ name) 
{ 
$ this—>name = $ name; 
} 
function showname() 
{ 
echo $ this— > name; 
} 
} 
$ obj = new Cstu; 
$obj -> getname(" 王 林 "); 
$ obj -> showname( ); 
?> 


接口 与 抽象 类 的 区 别 是 : 定义 接口 必须 省 略 abstract; 定义 抽象 类 必须 使 用 abstract。 


接口 中 只 能 包含 抽象 方法 , 且 抽 象 方法 必须 省 略 abstract; 抽象 类 中 可 包含 抽象 方法 与 非 抽 
象 方法 ,而 抽象 方法 必须 使 用 abstract。 


4.5 实例 一 一 设计 一 个 学 生 类 


【 例 4-8】 设计 一 个 学 生 类 ,在 其 中 定义 学 号 、 姓 名 、 性 别 等 属性 ,定义 构造 函数 用 于 对 
学 生 的 属性 赋值 ,定义 一 个 方法 用 于 输出 学 生 的 信息 。 
程序 代码 如 下 : 


<! DOCTYPE htm] > 

< htm]l > 

<head> 

<meta http — equiv = "Content - Type" content = "text/html; charset =utf - 8" /> 
<title> 学 生 类 示例 </title> 

</head> 
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<body> 
< form name = "forml" method = "post" action = ""> 
学 号 : < input name = "number" type = "text" size= "20"><br> 
姓名 : < input name = "name" type = "text" size = "20"><br> 
性 别 : < input type = "radio" name = "sex" value =" 男 "> 男 gnbsp; gnbsp; gnbsp; 
< input type= "radio" name = "sex" value= " 女 "> 女 <br> 
< input type = "submit" name = "button" value= "显示 "> 
</form> 
</body> 
</html > 
<?php 
class Student 
{ 
private $ number, $ name, $ sex; 
function __construct( $ xh, $ xm, $ xb) 
{ 
$ this 一 > number = $ xh; 
$ this—>name = $ xm; 
$ this—> sex= $ xb; 


下 

function show( ) 

| 
echo "学 号 : ". $ this 一 > number."<br>"; 
echo "姓名 : ". $ this 一 > name."<br>"; 
echo "性 别 : ". $ this 一 > sex; 


} 
} 
if (isset( $ _POST[ "button" ])) 
{ 
$ xh= $ _REQUEST[ "number" ]; 
$ xm= $ _REQUEST[ "name" ]; 
$ xb= $ _REQUEST["sex"]; 
$ stu= new student( $ xh, $ xm, $ xb); 
$ stu—> show(); 


4.6 ”项 目 实 训 一 一 设计 一 个 盒子 类 


实 训 目的 

(1) 掌握 PHP 中 类 的 定义 、 实 例 化 。 

(2) 掌握 PHP 类 中 属性 ,方法 的 访问 。 

实 训 要 求 

(1) 设计 一 个 表示 盒子 的 类 Box, 使 之 具有 宽度 .高 度 和 深度 等 属性 ,定义 构造 函数 对 
盒子 的 属性 进行 初始 化 ,定义 一 个 方法 showBox( ) 用 于 显示 盒子 的 体积 。 

(2) 当 用 户 在 表单 中 输入 数据 , 单 击 “ 求 体积 ”按钮 后 ,就 能 : 四 创建 Box 类 的 对 象 ; 
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回调 用 showBox() 方 法 。 表 单 界面 如 图 4-1 所 示 。 






































使 了 的 长 | 
使 了 的 宽 | 
盒子 的 高 | 








图 4-1 盒子 表单 界面 
思考 与 练习 


一 、 填空 题 

1. 在 进行 类 设计 时 ,通常 将 类 的 属性 设置 为 ( 填 访问 权限 ) 的 ,而 将 方法 设置 
为 ( 填 访 问 权限 ) 的 。 

2. 在 类 内 引用 非 静 态 成 员 的 格式 是 ,在 类 外 引用 非 静 态 成 员 的 格式 
是 。 不 管 类 内 还 是 类 外 ,引用 静态 成 员 的 格式 是 

3. 一 个 子 类 在 继承 一 个 的 同时 ,可 以 实现 多 个 ,这 样 就 解决 了 多 继 
承 的 问题 。 

二 、 简 答 题 

1. 除 例 4-5 外 ,再 举 一 个 方法 覆盖 的 例子 。 

2. 接口 和 抽象 类 有 什么 区 别 ? 











使 用 PHP 和 HTML 可 以 制作 出 内 容 丰 富 的 动态 网 页 。 网 页 的 架构 可 以 通过 HTML 
完成 ,数据 的 处 理 .与 数据 库 的 交互 通过 PHP 完成 。 本 章 将 具体 介绍 如 何 使 用 PHP 来 处 
理 Web 页 面 ,实现 与 用 户 的 交互 。 与 数据 库 的 交互 放 在 后 面 的 章节 中 介绍 。 
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。 掌握 获取 表单 数据 的 方法 。 

。 掌握 获取 URL 参数 值 的 方法 。 

。 掌握 页 面 跳 转 的 常用 方法 。 

。 学 会 利用 JavaScript 脚本 验证 表单 数据 。 
。 掌握 实现 会 话 的 步骤 。 


5.1 PHP 与 表单 


5.1.1 获取 表单 数据 的 方法 


在 Web 开发 中 ,通常 使 用 表单 来 实现 程序 与 用 户 的 交互 。 用 户 在 表单 上 输入 数据 , 然 
后 通过 单 击 按钮 或 超 链接 提交 表单 ,将 数据 传输 到 服务 器 以 进行 相应 的 处 理 。 

获取 表单 数据 可 以 使 用 $_POST 、$_GET 和 $_REQUEST 三 种 方法 。 

(1) $ _POST[ "表单 变量 "]: 取得 从 客户 端 以 POST 方式 传递 过 来 的 表单 变量 的 





value 值 。 

(2) $_GET[ "表单 变量 "]: 取得 从 客户 端 以 GET 方式 传递 过 来 的 表单 变量 的 
value 值 。 

(3) $_REQUEST[ "表单 变量 "]: 取得 从 客户 端 以 任意 方式 传递 过 来 的 表单 变量 的 
value 值 。 


在 上 面 三 种 方法 中 , 若 表单 变 量 未 存在 , 则 返回 null; 若 表 单 变 量 的 值 为 空 , 则 返回 ""。 


表单 变量 又 称 表单 控件 ,如 文本 框 , 单 选 按钮 、 复 选 框 等 。 在 同一 个 表单 中 ,多 个 单 选 按 
钮 成 组 出 现 , 用 户 只 能 从 中 选择 一 个 ,它们 的 名 称 要 设置 相同 ,如 name 二 "sex", 而 
$_REQUEST["sex"] 获 取 的 是 选中 的 那个 单 选 按钮 的 value 值 。 在 同一 个 表单 中 ,多 个 复 
选 框 也 成 组 出 现 , 但 允许 用 户 选择 多 个 ,它们 的 名 称 要 设置 相同 且 必 须 为 数组 形式 ,如 
name 王 "xq[]", 而 $_REQUEST["xq"] 获 取 的 是 一 个 数组 ,数组 中 保存 了 用 户 选择 的 所 有 
复 选 框 的 value 值 。 


5.1.2 实例 一 一 使 用 PHP 脚本 验证 表单 数据 


【 例 5-1】 在 EX5-1a. php 中 制作 一 个 学 生 信 息 表单 ,设计 界面 如 图 5-1 所 示 。 使 用 
PHP 脚本 验证 用 户 输入 的 数据 : 学 号 必须 输入 , 且 必 须 为 6 位 数字 ; 姓名 必须 输入 ; 性 别 
必须 选择 ; 出 生日 期 必须 输入 , 且 格 式 为 yyyy-mm-dd; 所 学 专业 和 兴趣 必须 选择 。 当 单 击 
“提交 ”按钮 后 ,车 用 户 未 输入 或 输入 错误 , 则 会 在 相应 控件 的 右边 显示 提示 信息 ,否则 ,会 跳 
转 到 EX5-1b. php 页 面 。 






































学 生 个 人 信息 
2 
7 | 
性 别 。 |O 男 C 女 
出 生日 期 ， 
所 专业， [ 韦 E 立 国 
和 
兴起， 口 游泳 口 看 电视 口上 网 
[ 酌 ] [时 | 





5-1 设计 界面 


在 EX5-1b.php 页 面 中 ,将 用 户 输入 的 信息 以 表格 形式 显示 出 来 。 
新 建 EX5-la. php 页 面 ,输入 以 下 代码 。 


<! DOCTYPE html > 
<html> 
<head> 
<meta http— equiv = "Content - Type" content = "text/html; charset = utf— 8" /> 
<title > 学 生 个 人 信息 </title> 
<style type= "text/css"> 
table{ 
width: 400px; 
margin:0 auto; 
background: 提 CCEFCC; 
} 
div{ 
text — align:center; 
} 
</style> 
</head> 
<body> 





<?php 
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if (isset( $ _REQUEST[ "BUTTON1"])) 


{ 


} 


?> 


$ test=1; 

$ XH= $ _REQUEST[ "XH" ] ; // 若 表单 变量 的 值 为 空 , 则 返回 "" 
$ XM = $ _REQUEST[ "XM" ]; 

$ XB= @ $ _REQUEST[ "SEX"]; // 若 未 选中 任何 选项 , 则 SEX 不 存在 


$ CSSJ= $ _REQUEST["Birthday"]; 

$ ZY= $ _REQUEST[ "ZY"]; 

$ BZ= $ _REQUEST[ "BZ"]; 

$ XQ = @ $ _REQUEST[ "XQ" ]; //$ XQ 为 数组 

// 若 正则 表达 式 中 含 *、$ ,只 有 正则 表达 式 与 字符 串 完全 匹配 ,该 函数 才 返回 1 

$ checkbirthday = preg_match( '/*\d{4} ~ (0?\d|1?[012]) - (0?\d|[12]\d|3[01]) S/ 

$ CSSJ); 

if($ XH=="") {$ XH1= "必须 输入 学 号 !"; $ test = 0;} 

elseif(preg_match( '/\d{6}/', $ XH) == 0) { $ XH1 = "学 号 必须 为 6 位 数字 !"; $ test = 0;} 

") {$ XM1= "必须 输入 姓名 !"; $ test = 0;} 

{ $ XB1 = "必须 选择 性 别 !"; $ test = 0;} 

"") {$CSSJ1 = "必须 输入 日 期 !"; $ test = 0;} 

elseif ( $ checkbirthday == 0) { $ CSSJ1 = "日 期 必须 为 yyyy mm-dd!"; $ test=0;} 

if ($2ZY=="") {$2ZY1 = "必须 选择 专业 !"; $ test = 0;} 

if (count( $ XQ) == 0) { $ XQ1 = "必须 选择 兴趣 !"; $ test = 0;} 

else $ XQ2 = implode(",", $ XQ); ”// 使 用 *,”, 将 数组 中 的 元 素 连接 成 一 个 字符 串 

if ( $ test ==1) 
header("Location:EX5— 1b. php?XH = $ XH&EXM = $ XM&SEX = $ XB&Birthday = $ CSSJ&ZY 
= $2Y&BZ= $ BZEXQ= $ XQ2"); 





< form method = "post" action = "EX5 — la. php"> 
<table width= "720" border = "1" cellspacing = "0"> 


<tr> 
<td height = "25" colspan = "2"><div> 学 生 个 人 信息 </div></td> 
</tr> 
< 
<td width="180" height = "25" align = "center"> 学 号 :</td> 
<tdwidth= "540" height = "25">< input name = "XH" type = "text"> &nbsp;<?php echo 
@ $xH1; ?></td> 
</tr> 
<tr> 
<td width="180" height = "25" align = "center"> 姓 名 : </td> 
<tdwidth= "540" height = "25">< input name = "XM" type = "text"> &nbsp;<?php echo 
@ $xXM1; ?></td> 
</tr> 
<tr> 
<td width="180" height = "25" align = "center"> 性 别 : </td> 
<td width = "540" height = "25"> 
< input name = "SEX" type= "radio" value =" 男 "> 男 
< input name = "SEX" type = "radio" value = " 女 "> 女 gnbsp;<?php echo @ $ XB1; ?> 
</td> 
</tr> 
<tr> 
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<td width= "180" height = "25" align = "center"> 出 生日 期 : </td> 
<td width = "540" height = "25">< input name = "Birthday" type = "text"> gnbsp; 
<?php echo @ $ CSSJ1; ?></td> 
</tr> 
<tr> 
<td width= "180" height = "25" align = "center"> 所 学 专业 : </td> 
<td width = "540" height = "25"> 
< select name = "ZY"> 
<option value = ""> 请 选择 专业 </option> 
< option > 计算机 科学 与 技术 </option > 


<option> 网 络 工程 </option> 
< option > 软件 工程 </option> 
</select > &nbsp;<?php echo @ $ ZY1; ?></td> 
</tr> 
<tr> 


<td width="180" height = "25" align = "center"> 备 注 : </td> 
<td width="540" height = "25">< textarea name = "BZ"></textarea></td> 
</tr> 
<tr> 
<td width="180" height = "25" align = "center"> 兴 趣 : </td> 
<td width= "540”height = "25"> 
< input name = "XQ[ ]”type = "checkbox”value = "游泳 "> 游泳 
<input name = "XQ[ ]”type = "checkbox" value = "看 电视 "> 看 电视 
< input name = "XQ[ ]" type = "checkbox" value =" 上 网 "> 上 网 snbsp;<?php echo 








@ $x01; ?> 
</td> 
</tr> 
<tr> 


<td height = "25" colspan = "2" align = "center"> 
< input type = "submit"” name = "BUTTON1” value = "提交 "> 
< input type = "reset" name = "BUTTON2"” value = " 重 置 "> 





</td> 
</tr> 
</table> 

</form> 

</body> 

</html > 

新 建 EX5-1b. php 页 面 ,输入 以 下 代码 。 
<?php 


$ XH= $ _REQUEST[ "XH"]; 
$ XM= $ _REQUEST[ "XM" ]; 
$ XB= $ _REQUEST[ "SEX" ]; 
$ CSSJ= $ _REQUEST[ "Birthday" ]; 
$ ZY= $ _REQUEST[ "ZY"]; 
$ BZ= $ _REQUEST["BZ"]; 
$ XQ= $ _REQUEST[ "XQ"]; 
?> 
<table width = "400" border = "1" align = "center" cellpadding = "0"> 
Er 
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<td width= "150" height = "30" align= "center"> 学 号 </td> 
<td height = "30"><?php echo $ XH; ?></td> 

</tr> 

<tr> 
<td width= "150" height = "30" align= "center"> 姓 名 </td> 
<td height = "30"><?php echo $ XM; ?></td> 

</tr> 

<tr> 
<td width= "150" height = "30" align = "center"> 性 别 </td> 
<td height = "30"><?php echo $ XB; ?></td> 

</tr> 

<tr> 
<td width= "150" height = "30" align = "center"> 出 生日 期 </td> 
<td height = "30"><?php echo $ CSSJ; ?></td> 

</tr> 

<tr> 
<td width= "150" height = "30" align = "center"> 所 学 专业 </td> 
<td height = "30"><?php echo $ ZY; ?></td> 

</tr> 

<tr> 
<td width= "150" height = "30" align = "center"> 备 注 </td> 
<td height = "30"> &nbsp;<?php echo $ BZ; ?></td> 

</tr> 

<tr> 
<td width= "150" height = "30" align = "center"> 兴 趣 </td> 
<td height = "30"><?php echo $ XQ; ?> 
</td> 

</tr> 

</table> 





5.2 URL 处 理 


5.2.1 获取 URL 参数 值 

Internet 上 每 个 网 页 都 有 它 自 己 的 地 址 , 称 为 URL( 统 一 资源 定位 符 )。URL 通常 的 格 
式 如 下 : 

url? 参 数 名 1= 值 1& 参数 名 2= 值 2& 参 数 名 3= 值 3 

获取 各 参数 值 的 格式 如 下 : 


$ _GET[ "参数 名 "] 
$ _REQUEST[ "参数 名 "] 


【 例 5-2】 获取 超 链接 参数 的 示例 。 


<ahref = "?no = 1&name = 张 三 "> 单 击 </a> 
<?php 

echo @ $ _GET["no"]; 

echo @ $ _GET[ "name" ]; 
?> 
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程序 解释 : 超 链接 中 *?" 号 前 面 省 略 将 要 访问 的 网 页 路 径 , 表示 当前 网 页 。 考 虑 到 第 
1 次 访问 网 页 时 ,服务 器 端 不 存在 no,$ _GET["no"] 将 返回 null, 无 法 输出 ,所 以 必须 在 
$_GET[L"no"] 前 面 加 入 错误 控制 符 @。 


5.2.2 解析 URL 


在 PHP 中 可 以 使 用 parse_url() 函数 解析 一 个 URL, 语 法 格式 如 下 : 
格式 1: 


数组 名 = parse_url(URL) 


功能 : 将 URL 的 各 个 组 成 部 分 分 开 ,并 分 别 存 人 数组 中 。 

说 明 : 本 函数 不 是 用 于 解析 URL 的 合法 性 ,不 完整 的 URL 也 可 接受 。URL 的 组 成 部 
分 有 : scheme( 协 议 )、host( 主 机 )、port( 端 口号 )、user( 用 户 名 ) 、pass (密码 )、path( 路 径 ) 、 
query( 在 问号 ? 之 后 的 内 容 ) ,fragment( 在 散 列 号 # 之 后 的 内 容 )。 

例如 : 

<?php 

$url = "http://username: password@www. php. net/index. php?arg = value # anchor"; 

$a= parse_url( $ url); 

print_r( $a); // 输 出 所 有 元 素 的 键 名 和 值 

/* 输出: Array ( [scheme] => http [host] => www. php.net [user] => username 
[pass] => password [path] => /index.php [query] => arg= value 
[fragment] => anchor ) 

*/ 


?> 
格式 2: 
变量 名 = parse_url(URL, 参数 ) 


功能 : 获取 URL 中 的 某 一 个 组 成 部 分 。 

说 明 : 参数 是 指 PHP_URL_SCHEME、PHP_URL_HOST、PHP_URL_PORT、PHP_ 
URL_USER.PHP_URL_PASS.PHP_URL_PATH、PHP_URL_QUERY 或 PHP_URL. 
FRAGMENT 中 的 一 个 。 

例如 : 

<?php 

$ url= "http://username: password@www. php. net/index. php?arg = value# anchor"; 
$a= parse_url( $ url, PHP_URL_PATH); 


echo $a; // 输 出 :"/index. php" 
?> 


5.2.3 ”URL 编码 和 解码 


如 果 URL 参数 中 含有 汉字 ,为 防止 在 传递 过 程 中 出 现 乱 码 ,需要 对 URL 进行 编码 。 
所 谓 编码 就 是 将 URL 中 除了 字母 .数字 、“-”_”. "之 外 的 所 有 字符 都 蔡 换 为 一 个 以 % 开 头 
后 跟 2 位 十 六 进 制 数 的 3 位 字符 串 。 

URL 编码 的 语法 格式 如 下 : 
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urlencode( URL) 


例如 : 
<?php 
$url = "http://www. php. net"; 
echo urlencode( $ url); // 输 出 "http% 3A % 2F % 2Fwww. php. net" 
?> 
URL 编码 后 需要 使 用 urldecode( ) 进 行 解码 ,语法 格式 如 下 : 
urldecode( URL) 
功能 ; 将 URL 中 所 有 以 “%" 开 头 后 跟 2 位 十 六 进 制 数 的 3 位 字符 串 进行 解码 ,并 返回 
解码 后 的 字符 串 。 例 如 : 


<?php 

$url = "http% 3A% 2F % 2Fwww. php. net"; 

echo urldecode( $ url); // 输 出 "http://www. php. net" 
?> 


5.3 页面 跳 转 

PHP 网 页 由 PHP 脚本 、HTML 标记 、JavaScript 脚本 三 部 分 组 成 ,每 部 分 都 可 实现 页 
面 跳 转 。 

5.3.1 在 PHP 脚本 中 实现 页 面 跳 转 

在 PHP 脚本 中 ,使 用 header() 函 数 可 实现 页 面 跳 转 , 语 法 格式 如 下 : 

header("Location: 文 件 名 ") 

例如 : 

header ("Location: http://www. 163. com" ); 

5.3.2 在 HTML 标记 中 实现 页 面 跳 转 


在 HTML 标记 中 ,使 用 提交 表单 .文件 超 链接 都 能 实现 页 面 跳 转 。 

1. 提交 表单 

将 二 form 二 标记 的 action 属性 设置 为 要 跳 转 的 页 面 ,提交 表单 后 就 跳 转 到 该 页 面 。 
例如 : 


< form name = "forml" method = "post" action = "index. php"> 





< input type = "text" name = "no" /> 

< input type = "submit" name = "button" value = "提交 " /> 
</form> 
2. 文件 超 链 接 
语法 格式 如 下 : 


<ahref = "文件 名 "> 
例如 : 


<a href = "index. php?no = 1&name = 张 三 "> 单 击 </a> 


5.3.3 在 JavaScript 脚本 中 实现 页 面 跳 转 
在 JavaScript 脚本 中 ,从 当前 网 页 跳 转 到 其 他 网 页 的 格式 如 下 : 


window. location. replace( "文件 名 ") 


例如 : 


< script language = "javascript"> 
window. location. replace(" index. php?no = 1&name = 张 三 "); 
</script > 


说 明 : window. location. replace() 是 一 个 JavaScript 语句 ,JavaScript 语句 的 存放 位 置 


如 下 。 


(1) 直接 放 在 二 script language 王 "javascript" 过 与 二 /script 二 中 。 
(2) 放 在 按钮 控件 的 onclick 事件 之 后 。 例 如 : 


< input type = "button" value = "打开 " name = "Bl"onclick = "javascript 语句 "> 


【 例 5-3〗 将 数据 从 一 个 页 面 传送 到 另 一 页 面 的 方式 演示 。 
(1) 在 EX5-3a. php 页 面 创建 如 图 5-2 所 示 的 初始 界面 ,在 其 中 创建 三 种 页 面 跳 转 方 











于 将 “no 一 1,name 一 张 三 ”" 从 EX5-3a. php 传送 到 EX5-3b. php 的 方式 。 








将 “no=1，nane= 张 三 "从 EX5-3a. php 传 送 到 EX5-3b. php 的 方式 


1. 在 php 脚 本 中 实现 页 面 跳 转 执行 


2. 文件 超 链 接 跳 到 EX5-3b, php 
3. 在 JavaScript 脚 本 中 实现 页 面 跳 转 执行 














5-2 ”EX5-3a. php 的 初始 界面 
具体 代码 如 下 : 


<?php 
if (isset( $ _POST["buttonl"])) 
{ 
header( "Location:EX5 - 3b. php?no = 1g&name = 张 三 "); 
} 
?> 
< form name = "forml" method = "post”action = ""> 
<table width= "450" border = "1" align = "center" cellspacing = "0"> 
<tr> 
<td height = "30" colspan = "2" align = "center"> 将 "no = 1,name = 张 三 " 从 EX5 - 3a. php 传送 
到 EX5 - 3b.php 的 方式 </td> 
</tr> 
<tr> 
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<td width= "300" height = "30">1. 在 php 脚本 中 实现 页 面 跳 转 </td> 
<td width = "150" height = "30" align = "center">< input type = "submit" name = "button1" 
value = "执行 " /></td> 
</tr> 
<tr> 
<td width="300”height = "30"> 2. 文 件 超 链接 </td> 
<td width= "150" height = "30" align = "center"><a href = "EX5 - 3b. php?no = 1&name = 张 三 "> 
跳 到 EX5 - 3b. php </a></td> 
</tr> 
<tr> 
<td width= "300" height = "30"> 3. 在 javascript 脚本 中 实现 页 面 跳 转 </td> 
<td width= "150" height = "30" align = "center">< input type = "button" name = "button3" 
value = "执行 " onclick = "window. location. replace( 'EX5 - 3b. php?no = 1&name = 张 三 ')"/> 
</td> 
</tr> 
</table> 
</form> 


(2) 创建 EX5-3b. php 页 面 ,用 于 接收 从 EX5-3a. php 传送 过 来 的 数据 。 单 击 * 返 回 " 按 
钮 ,就 能 返回 EX5-3a. php 页 面 。 

具体 代码 如 下 : 
<?php 

$no= $ _REQUEST["no"]; 

$name = $ _REQUEST["name" ]; 

echo "学 号 :"，$ no "姓名 :"，$ name; 
?> 
<br /><br /> 
< input type = "button" name = "button" value = "返回 " 

onclick = "window. location. replace( 'EX5 - 3a. php ')"/> 


5.4 在 PHP 中 嵌入 JavaScript 


5.4.1 JavaScript 简介 


JavaScript 是 在 1995 年 ,由 Netscape 公司 的 Brendan Eich, 在 Netscape 浏览 器 上 首次 
设计 成 功 的 。 虽 然 名 字 中 含有 Java, 但 它 与 Java 语言 是 两 种 不 同 的 语言 ,但 JavaScript 的 
语法 与 Java 语言 非常 类 似 。 

JavaScript 是 一 种 网 页 脚本 语言 ,JavaScript 代码 可 以 很 容易 嵌入 HTML 网 页 中 ,为 网 页 
添加 各 式 各 样 的 动态 功能 ,为 用 户 提供 更 流畅 美观 的 浏览 效果 。JavaScript 具有 以 下 特点 。 

(1) 脚本 语言 。JavaScript 是 一 种 解释 型 脚本 语言 。 

(2) 区 分 字母 大 小 写 。JavaScript 是 一 种 区 分 字母 大 小 写 的 语言 。 

(3) 弱 变量 类 型 。JavaScript 中 的 变量 为 弱 变 量 类 型 , 即 变量 的 类 型 由 它 所 赋值 的 类 型 
决定 。 

(4) 跨 平台 性 。JavaScript 脚本 语言 不 依赖 于 操作 系统 , 仅 需 要 浏览 器 的 支持 。 目 前 


JavaScript 已 被 大 多 数 浏览 器 支持 。 

(5) 动态 性 。 主 要 用 来 向 HTML 页 面 添加 交互 行为 。 

JavaScript 脚本 可 以 直接 嵌入 HTML 页 面 ,也 可 写成 单独 的 js 文件 。 例 如 : 

首先 ,在 code. js 中 写 人 : window. alert(" 第 一 个 JavaScript 程序 ") ,然后 在 网 页 中 插入 
script src 二 "code. js" type 一 "text/javascript" 之 一 /script 盖 来 导 和 人 code. js 文件。 


5.4.2 JavaScript 语句 

1. 定义 变量 

JavaScript 变量 无 须 类 型 声明 ,定义 变量 的 格式 如 下 : 
var 变量 名 [ = 初始 值 ]; 

例如 : 


vara=5; 


2. if 语句 

证 语句 也 叫 分 支 语句 ,语法 格式 如 下 : 

if (表达 式 ) 语 句 1 [else 语句 2] 

功能 : 当 表 达 式 的 值 为 真 时 ,就 执行 “语句 1”, 和 否则 执行 “语句 2”。 
3. switch 语句 

switch 语句 也 叫 多 分 支 语句 ,语法 格式 如 下 : 


switch( 表 达 式 ) 
{ case 常量 1: 语句 块 1; 
break; 
case 常量 2: 语句 块 2; 
break; 


Case 常量 n: 语句 块 n; 
break; 
[ default: 语句 组 n+1;] 
} 
功能 : 首先 计算 表达 式 的 值 ,如 果 表达 式 值 与 某 个 case 块 的 常量 相等 ,就 转 去 执行 该 
case 块 的 语句 , 当 表达 式 值 与 任何 case 块 的 常量 都 不 相等 时 ,就 执行 default 中 的 语句 。 
4. 循环 语句 
JavaScript 语言 共有 3 种 循环 语句 : for 语句 、while 语句 .do-while 语句 ,它们 的 语法 格 
式 与 PHP 相同 ,这 里 不 再 袭 述 。 
5. 定义 函数 
JavaScript 的 函数 定义 格式 与 PHP 相同, 即 : 


function 函数 名 ( 形 参 表 ) 
{ } 


第 5 章 ， 构 建 PHP 互 动 网 页 【77 


6. 注释 语句 

JavaScript 语言 的 注释 与 PHP 相同 , 即 : 
单行 注释 : // 

多 行 注释 : /*...*/ 


5.4.3 JavaScript 内 置 对 象 


JavaScript 提供 了 许多 内 置 对 象 ,构成 对 象 体系 ,如 图 5-3 所 示 。 最 高 一 层 是 window 
(浏览 器 ) , 它 包 含 document( 网 页 页 面 )、history( 历 史 ) ,location( 位 置 ) 等 子 对 象 ,这 些 子 对 
象 又 有 自己 的 属性 和 下 一 层 的 子 对 象 。 因 此 ,在 访问 一 个 对 象 时 ,原则 上 从 window 开始 ， 
由 表 及 里 逐次 取 其 子 对 象 ,直到 取 到 要 访问 的 对 象 为 止 ,但 在 实际 使 用 时 ,window 可 以 省 
略 。 例 如 ,将 网 页 页 面 的 背景 色 设置 为 蓝 色 的 JavaScript 语句 为 ， 


window. document. bgColor = "blue" 
























































5.4.4 window 对 象 的 方法 


1. alert 方法 
格式 ; 


window.alert( 字 符 串 ); 























图 5-3 JavaScript 对 象 体系 


功能 : 产生 一 个 对 话 框 ,只 含 一 个 “确定 ”按钮 。 


2. confirm 方法 
格式 : 


x= window. confirm( 字 符 串 ); 





anchors 
location applets 
window document forms 表单 控件 
history nage 
links 


功能 : 产生 一 个 对 话 框 ,含有 “确定 “取消 "按钮 。 当 用 户 单 击 “ 确 定 ” 按 钮 时 ,返回 


true; 单 击 “取消 ”按钮 时 ,返回 false。 
3. prompt 方法 
格式 : 
x= window. prompt( 提 示 信 息 [, 默 认 值 ]); 


程 








功能 : 产生 一 个 输入 框 , 让 用 户 输入 数据 ,并 返回 一 个 字符 串 给 x。 

注意 : 若 运行 brompt 方法 不 会 产生 输入 框 , 则 在 IE 中 选择 "工具 ”~“Internet 选项 ”一 
“安全 ”>“ 自 定义 级 别 ”, 在 “安全 设置 "对话 框 中 启用 “允许 网 站 使 用 脚本 窗口 提示 获得 
信息 ”。 

【 例 5-4】 从 键盘 输入 三 个 数 ,将 最 大 数 输 出 。 


< script language = "javascript"> 
X= Number(window. prompt ("x=" 






y= Number(window. prompt("Y 

z= Number(window. prompt("z = ")); 

if (x>y)max= x;else max = y; 

if (z>max) max= 2; 

window.alert(" 最 大 数 为 :" + max); 
</script > 


4. open 方法 

格式 : 

window. open(" 网 页 文件 名 "[," 窗 口 名 称 "] [, "窗口 风格 "]); 

对 象 名 = window. open(" 网 页 文件 名 ”[, "窗口 名 称 "] [, "窗口 风格 "]); 

功能 : 打开 一 个 新 窗口 ,用 于 显示 指定 的 网 页 ,并 返回 窗口 对 象 。 

注意 : 窗口 名 称 : 即 新 打开 的 窗口 的 名 称 ,常用 "代替 。 窗 口 风格 主要 包括 : width 二 n， 
height 二 n,menubar [三 1|0] 等 选项 ,选项 间 用 "," 作 为 分 隔 符 。 若 省 略 窗口 风格 , 则 窗口 按 
默认 的 风格 显示 。 

5. close 方法 

格式 1: 


window.close( ); 


功能 : 关闭 当前 窗口 。 
格式 2: 
窗口 对 象 名 .close( ); 


功能 : 关闭 指定 的 窗口 对 象 。 

【 例 5-5】 在 EX5-5. php 页 面 中 , 单 击 * 打 开 ” 按 钮 ,就 能 在 新 窗口 中 显示 common. htm 
网 页 ; 单 击 “ 关 闭 ” 按 钮 ,就 能 关闭 刚才 打开 的 窗口 。 

主要 代码 如 下 : 


< script language = "javascript"> 

function check() 

{ 

x= window. open ("common. htm","","width= 400, height = 200" ); 

} 
</script > 
< input type = "button" name = "open” value= "打开 " onclick = "check()"/> 
< input type = "button" name = "close" value = "关闭 " onclick="x.close()" /> 
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6. print 方法 
格式 : 


window. print(); 

功能 : 打印 当前 窗口 。 
7. setTimeout 方法 
格式 : 


window. setTimeout( "函数 名 ()", 延 时 时 间 ); 
对 象 名 = window，setTimeout(" 函 数 名 ()", 延 时 时 间 ); 


功能 : 设置 一 个 计时 器 ,用 来 在 指定 的 时 间 后 调用 一 个 函数 ,并 返回 一 个 计时 器 标识 。 
延 时 时 间 的 单位 是 毫秒 。 

8. clearTimeout 方法 

格式 : 

window. clearTimeout( 计 时 器 标识 ); 

功能 : 清除 计时 器 标识 。 

【 例 5-6】 在 EX5-6. php 页 面 中 , 单 击 * 开 始 ” 按 钮 ,就 能 在 页 面 显示 一 个 实时 的 数字 时 
钟 ; 单 击 “ 停 止 " 按 钮 ,数字 时 钟 就 停止 下 来 ,如 图 5-4 所 示 。 

















数字 时 名 
16:11:51 
医 到 [EL 
图 5-4 数字 时 钟 
主要 代码 如 下 : 
<table width= "200" border ="1" align = "center" cellpadding = "0"> 
<tr> 
<td height = "30" align = "center"> 数 字 时 钟 </td> 
</tr> 
<tr> 
<td height = "30" align = "center" id = "wl"> gnbsp;</td> 
</tr> 
<tr> 


<td height = "30" align = "center">< input type = "button" name = "button" value = " 开 始 " 
onclick = "begin()" /> 
< input type = "button" name = "button2" value = " 停 止 " onclick = "stop()"/></td> 
</tr> 
</table> 
< script language = "javascript"> 
var id; 
function begin() 
{ 
var today = new Date(); //today 包含 年 月 日 时 分 秒 星期 几 信息 


var hour = today. getHours(); 
var minute = today. getMinutes( ); 
Var second = today. getSeconds( ); 
if (minute<10) minute= "0" + minute; 
if (second< 10) second = "0" + second; 
wl1. innerHTML = hour + ":" + minute+":"+ second; 
id = setTimeout("begin( )", 1000); 

} 

function stop() 

{ window. clearTimeout( id);} 

</script > 


5.4.5 window 对 象 的 子 对 象 


1. document 子 对 象 


document 子 对 象 的 常用 属性 和 方法 如 下 。 
(1) bgColor 属性 

bgColor 属性 用 于 设置 页 面 背景 颜色 ,例如 : 
document. bgColor = "blue"; 

(2) fgColor 属性 

fgColor 属性 用 于 设置 页 面前 景 颜色 .例如 : 
document. fgColor = "red"; 

(3) title 属性 

title 属性 用 于 设置 页 面 的 标题 ,例如 : 
document. title= "与 时 俱 进 "; 

(4) write 方法 

格式 : 

document. write( 表 达 式 表 ) 

功能 : 输出 各 表达 式 的 值 。 

2. location 子 对 象 

location 子 对 象 的 常用 方法 如 下 : 

window. location. replace( "文件 名 "); 

功能 : 转 去 执行 指定 的 网 页 文件 。 

3. history 子 对 象 

history 子 对 象 的 常用 方法 如 下 。 

(1) forward 方法 

格式 : 


window. history. forward( ); 
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功能 : 前 进 至 当前 页 面 之 后 访问 过 的 页 面 ,相当 于 浏览 器 工具 栏 上 的 “前 进 ” 按 钮 。 


(2) back 方法 
格式 : 


window. history. back( ); 


功能 : 后 退 至 当前 页 面 之 前 访问 过 的 页 面 ,相当 于 浏览 器 工具 栏 上 的 “后 退 " 按 钮 。 


【 例 5-7】 前 进 、 后 退 用 法 的 示例 。 


(1) 在 EX5-7a. php 页 面 中 ,首先 通过 超 链接 使 a、b 页 面 形成 前 后 关系 ,才能 使 用 “前 


进 ”“* 后 退 " 按 钮 。 主 要 代码 如 下 : 
<p> 这 是 a 页 面 </p> 


<p> 首 先 ,通过 超 链接 使 a.b 页 面 形成 前 后 关系 ,才能 使 用 "前 进 " 后退" 按钮 . 


<br /><a href = "EX5 - 7b.php"> 进 入 b 页 面 </a></p> 


<p >< input type = " button” name = "button”value =" 前 进 ”"onclick = "window. history. 


forward();"/></p> 


(2) 在 EX5-7b. php 页 面 中 , 单 击 “ 后 退 "” 按 钮 ,就 能 返回 EX5-7a. php 页 面 。 主 要 代码 如 下 : 


<p> 这 是 b 页 面 </p> 


<p><input type = "button" name = "button" value = "后 退 " onclick = "window. history. back();"/> 


</p> 


5.4.6 实例 一 一 使 用 JavaScript 脚本 验证 表单 数据 


【 例 5-8】 将 例 5-1 中 的 EX5-1a. php、EX5-1b. php 页 面 分 别 男 存 为 EX5-8a. php、 


EX5-8b. php 页 面 。 


在 EX5-8a. php 页 面 中 , 改 用 JavaScript 脚本 验证 用 户 输入 的 数据 。 当 单 击 “提交 ?按钮 
后 , 若 用 户 未 输入 或 输入 错误 , 则 出 现 对 话 框 提 示 错 误 信 息 ; 否则 ,会 跳 转 到 EX5-8b. php 


页 面 。 
EX5-8a. php 的 代码 如 下 : 
<! DOCTYPE htm] > 


<html> 
<head> 


<title > 学生 个 人 信息 </title> 


<style type= "text/css"> 
table{ 
width:400px; 
margin:0 auto; 


background: ## CCFECC; 


) 
div{ 
text — align:center; 
} 
</style> 
</head> 
<body> 


< script language = "javascript"> 


function check() 


PHP 动 态 网 站 开发 案例 教程 





var xh= /^\d{6} $ /; 
if (document. form1. XH. value == "") 

{ alert(" 必 须 输入 学 号 !"); document. form1. XH. focus(); return false;} 

// 在 字符 串 中 查找 与 正则 表达 式 xh 相 匹 配 的 内 容 , 若 找 到 , 则 返回 true; 否则 返回 false 
else if (xh. test(document. form]. XH. value) == false) 

{ alert(" 学 号 必须 为 6 位 数字 !");document. forml. XH. focus( ); return false;} 


if (document. forml. XM. value == "") 
{ alert ("必须 输入 姓名 !"); 
document. form1. XM. focus( ); 
return false; 


if (document. forml. SEX(0). checked == false && document. forml .SEX(1). checked == false) 
{ alert(" 必 须 选 择 性 别 !"); 
document. forml. SEX( 0). focus( ); 
return false; 


var cssj=/*\d{4} - (0?\d|l1?[012]) - (0?\d|[12]\d|3[01]) $/; 

if (document. form1. Birthday. value == "") 

{ alert(" 必 须 输入 日 期 !"); document. form1.Birthday. focus();return false;} 

else if (cssj. test(document. form1.Birthday.value) == false) 

{ alert(" 日 期 必须 为 YYYY- mm- dd!" ); document. form1.Birthday. focus();return false;} 





if (document. forml. ZY.value== "") 
{ alert(" 必 须 选 择 专业 !"); 

document. forml. ZY. focus( ); 

return false; 

} 
if (document. forml. ah1. checked == false && document. forml. ah2. checked = = false && 
document. form1l. ah2. checked == false) 
{ alert(" 必 须 选 择 兴 趣 !"); 

document. forml. ahl. focus(); 

return false; 


} 
</script > 
< form name = "forml" method = "post" action = "EX5 - 8b. php" onSubmit = "return check()"> 
<table width = "720" border ="1" cellspacing = "0"> 
<tr> 
<td height = "25" colspan = "2"><div > 学生 个 人 信息 </div></td> 
</tr> 
<tr> 
<td width = "180" height = "25" align = "center"> 学 号 :</td> 
<td width = "540”height = "25">< input name = "XH" type = "text"> gnbsp;</td> 
</tr> 
二 下 
<td width= "180" height = "25" align = "center"> 姓 名 : </td> 
<td width = "540" height = "25">< input name = "XM" type = "text"> &nbsp;</td> 
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</tr> 
<tr> 
<td width="180" height = "25" align = "center"> 性 别 : </td> 
<tdwidth="540" height = "25"> 
< input name = "SEX" type= "radio" value = " 男 "> 男 
< input name = "SEX" type= "radio" value = " 女 "> 女 gnbsp; </td> 
</tr> 
二 
<td width = "180" height = "25" align = "center"> 出 生日 期 : </td> 
<td width= "540" height = "25">< input name = "Birthday" type = "text"> &nbsp;</td> 
</tr> 
<tr> 
<td width= "180" height = "25" align = "center"> 所 学 专业 : </td> 
<td width = "540”height = "25"> 
< select name = "ZY"> 
<option value = ""> 请 选择 专业 </option> 
<option value= "计算 机 科学 与 技术 "> 计算 机 科学 与 技术 </option> 





<option value= "网 络 工程 "> 网 络 工程 </option> 
<option value = "软件 工程 "> 软件 工程 </option > 
</select > gnbsp; 
</td> 
</tr> 
<tr> 


<td width= "180" height = "25" align = "center"> 备 注 : </td> 
<td width="540" height = "25">< textarea name = "BZ"></textarea></td> 
</tr> 
<tr> 
<td width="180" height = "25" align = "center"> 兴 趣 : </td> 
<td width="540" height = "25"> 
< input name = "XQ[ ]”id= "ahl"” type = "checkbox" value = "游泳 "> 游泳 
< input name = "XQ[ ]”id= "ah2"” type = "checkbox" value = "看 电视 "> 看 电视 
< input name = "XQ[ ]" id = "ah3" type = "checkbox" value = "上 网 "> 上 网 &nbsp; 
</td> 
</tr> 
<tr> 
<td height = "25" colspan= "2" align = "center"> 
< input type = "submit" name = "BUTTON1" value = "提交 "> 
< input type = "reset" name = "BUTTON2"”value = " 重 置 "> 


</td> 
</tr> 
</table> 

</form> 

</body > 

</html > 

EX5-8b. php 的 代码 如 下 : 
<?php 


$ XH= $ _REQUEST[ "XH" ]; 
$ XM= $ _REQUEST[ "XM" ]; 
$ XB= $ _REQUEST["SEX" ]; 





$CSSJ = $_REOUEST["Birthday"]; 
$ ZY = $ _REQUEST[ "ZY" ]; 
$ BZ= $ _REQUEST[ "BZ" ]; 
$ XQ = $ _REQUEST["XQ" ]; //$ XQ 是 数组 
$ XQ1 = implode(",",$ XQ); // 使 用 ",", 将 数组 中 的 元 素 连接 成 一 个 字符 串 
?> 
<table width = "400" border ="1" align = "center" cellpadding = "0"> 
<tr> 
<td width= "150" height = "30" align = "center"> 学 号 </td> 
<td height = "30"><?php echo $ XH; ?></td> 
</tr> 
<tr> 
<td width= "150" height = "30" align = "center"> 姓 名 </td> 
<td height = "30"><?php echo $ XM; ?></td> 
</tr> 
<tr> 
<td width= "150" height = "30" align = "center"> 性 别 </td> 
<td height = "30"><?php echo $ XB; ?></td> 
</tr> 
<tr> 
<td width = "150" height = "30" align = "center"> 出 生日 期 </td> 
<td height = "30"><?php echo $ CSSJ; ?></td> 
tr> 
<tr> 
<td width= "150" height = "30" align = "center"> 所 学 专业 </td> 
<td height = "30"><?php echo $ ZY; ?></td> 
</tr> 
<tr> 
<td width= "150" height = "30" align = "center"> 备 注 </td> 
<td height = "30"> gnbsp;<?php echo $ BZ; ?></td> 
</tr> 
<tr> 
<td width = "150" height = "30" align = "center"> 兴 趣 </td> 
<td height = "30"><?php echo $ XQ1; ?> 
</td> 
</tr> 
</table> 


注意 : 在 PHP 中 ,多 个 复 选 框 的 name 值 要 设置 相同 且 必 须 为 数组 形式 ,但 id 值 可 互 


不 相同 。 


5.5 会 话 管理 


如 ， 


根据 HTTP 协议 的 特点 ,客户 端 每 次 与 服务 器 的 对 话 都 被 当 作 一 个 单独 的 过 程 。 例 




















户 使 用 用 户 名 和 密码 进入 登录 页 面 后 ,用 户 名 和 密码 没有 被 保存 , 当 用 户 请 求 访问 第 


二 个 页 面 时 ,该 用 户 的 请 求 将 不 会 被 HTTP 所 接受 ,这 时 就 需要 使 用 会 话 管理 。 会 话 管理 
的 思想 就 是 指 在 网 站 中 通过 一 个 会 话 跟踪 用 户 , 记 录 下 用 户 的 信息 ,实现 信息 在 页 面 间 的 
传递 。 
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5.5.1 会 话 的 工作 原理 

1. 什么 叫 会 话 

用 户 从 打开 某 个 网 页 开始 到 关闭 该 网 页 ,或 进入 另 一 个 新 网 页 为 止 的 整个 过 程 称 为 会 
话 。 换 句 话说, 用户 持 续 停留 在 某 个 网 页 的 过 程 称 为 会 话 。 会 话 也 称 Session。 

2. 会 话 的 产生 

当 浏览 器 连接 一 个 Web 服务 器 时 ,服务 器 就 会 为 它 创建 一 个 Session ,同时 自动 分 配 一 


个 session_id, 用 以 标识 浏览 器 的 唯一 身份 。 在 客户 端 , 浏 览 器 会 将 此 session_id 值 存 人 本 
地 的 Cookie 中 ,如 图 5-5 所 示 。 


服务 器 为 A 的 浏览 器 
客户 机 A 的 Cookie 创建 Session 








| 


i 




















图 5-5 Session 与 Cookie 的 关系 


输出 session_id 的 语句 为 echo session_id();, 该 语句 前 面 必须 有 session_start();。 

每 个 浏览 器 有 各 自 的 Session, 用 于 保存 浏览 器 独 享 的 信息 。 当 浏览 器 关闭 时 ,Session 
就 自动 消失 。 

3. Session 的 超时 期 限 

Session 的 超时 期 限 默 认为 24 分 钟 ( 见 php. ini 文件 ,session. gc_maxlifetime 二 1440 秒 )。 
如 果 停 留 在 某 个 网 页 的 时 间 超 过 24 分 钟 , 则 浏览 器 对 应 的 Session 会 自动 消失 ,此 时 若 再 
访问 新 的 网 页 , 则 服务 器 将 为 浏览 器 创建 一 个 新 的 Session。 如 果 停 留 在 每 个 网 页 的 时 间 均 
不 超过 24 分 钟 , 则 浏览 器 对 应 的 Session 始终 存在 。 

当然 可 以 修改 Session 的 超时 期 限 , 如 将 超时 期 限 修改 为 1 分 钟 ,语句 为 session_set_ 
cookie_params(60); ,该 语句 前 面 不 能 有 session_start();。 


5.5.2 实现 会 话 


在 PHP 中 实现 会 话 的 主要 步骤 如 下 。 

(1) 启动 会 话 。 

(2) 定义 会 话 变 量 。 

(3) 访问 会 话 变 量 。 

(4) 删除 会 话 变 量 。 

(5) 删除 会 话 。 

定义 会 话 变量 访问 会 话 变量 、 删 除 会 话 变量 删除 会 话 之 前 ,都 要 先 启 动 会 话 。 
1. 启动 会 话 

格式 : 


session_start( ); 


功能 : 首先 检查 浏览 器 对 应 的 session_id 是 否 存在 ,如 果 不 存 在 则 创建 一 个 ; 否则 打开 
该 会 话 空间 。 


$ _SESSION[ "变量 名 "] = 值 ; 

功能 : 在 会 话 空间 中 定义 各 个 会 话 变量 。 会 话 变量 保存 在 预定 义 变量 $ _SESSION 
中 ,用 于 保留 各 个 浏览 器 独 享 的 信息 。 

3. 访问 会 话 变量 

格式 : 


echo $ _SESSION[ "变量 名 "]; 


说 明 : 车 未 存在 指定 的 变量 名 , 则 $_SESSION[ "变量 名 "J 返回 null。 




















4. 删除 会 话 变量 

unset( $ _SESSION[ "变量 名 "]); ”// 删 除 指定 的 会 话 变量 
session_unset( ); // 删 除 所 有 会 话 变量 ,但 仍 保留 会 话 空 间 
5. 删除 会 话 

格式 ; 


session_destroy( ); 


功能 : 删除 会 话 所 占 空 间 , 即 删除 session_id。 
例如 : 
?php 
session_start(); 
session_destroy( ); 
?> 


【 例 5-9】 在 EX5-9a. php 网 页 中 ,设置 Session 的 超时 期 限 为 60 秒 ,向 Session 空间 添 
加 信息 ,输出 session_id。 运 行 EX5-9a. php 网 页 , 单 击 超 链 接 后 就 能 跳 转 到 EX5-9b. php 网 
页 ,要求 EX5-9b. php 网 页 用 于 显示 Session 空间 的 信息 和 session_id。 
EX5-9a. php 网 页 的 代码 如 下 : 
<?php 
session_set_cookie_params(60); // 将 超时 期 限 修 改 为 60 秒 
session_start( ); 
$ _SESSION[ "no" ] = 1; 
$ _SESSION[ "name" ] = " 张 三 "; 


echo "浏览 器 对 应 的 session_id 为 : ".session_id(); 
?> 


EX5-9b. php 网 页 的 代码 如 下 : 


<?php 
session_start(); 
echo "学 号 : ". @ $ _SESSION["no"]."<br>"; 
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echo "姓名 : ". @ $ _SESSION["name"]."<br>"; 
echo "浏览 器 对 应 的 session_id 为:". session_id(); 
> 


注意 ; 如 果 停 留 在 EX5-9a. php 的 时 间 超 过 60 秒 , 就 不 会 显示 Session 空间 的 信息 。 
5.5.3 Session 的 应 用 


利用 Session 可 以 实现 密码 验证 、 购 物 车 功能 。 
【 例 5-10】 利用 Session 创建 购物 车 。 
(1) 创建 一 个 名 称 为 gwcl. php 的 网 页 ,主要 代码 如 下 : 


<?php 
if (isset( $ _REQUEST[ "button"])) 
{ 
session_start(); 
$ _SESSION["s1"] = @ $ _REQUEST["s1"]; 
$ _SESSION["s2"] = @ $ _REQUEST["s2" ]; 
$ _SESSION["s3"] = @ $ _REQUEST["s3" ]; 
} 
?> 
< form id= "forml" name = "forml" method= "post" action=""> 
<p> 肉 铺 : </p> 
<p><input name = "C1" type = "checkbox" value = "猪肉 " /> 
猪肉 &nbsp; gnbsp; 
< input name = "C2" type= "checkbox" value = "牛肉 " /> 
牛肉 &nbsp; &nbsp; 
< input name = "C3" type = "checkbox" value = "羊肉 " /> 
羊肉 </p> 
<p> < input type = "submit" name = "button" value = "提交 " /> 
< input type = "button" name = "button2" value = "查看 ”onclick = "window. 
location. replace( 'gwc2. php');"/></p> 
</form> 


(2) 创建 一 个 名 称 为 gwc2. php 的 网 页 ,主要 代码 如 下 : 
<p> 你 选择 的 结果 是 : </p> 


<?php 
Session_start() 
$str=""; 


if (@$ _SESSION["s1"]!= null) $ str= $ str. $_SESSION["s1"]; 
if (@$ _SESSION["s2"]!= null) $ str= $ str.",". $_SESSION["s2"]; 
if (@$ _SESSION["s3"]!= null) $ str= $ str.",". $_SESSION["s3"]; 
echo $ str; 

?> 


5.6 项 目 实 训 


实 训 1 使 用 PHP 脚本 验证 表单 数据 


实 训 目的 
(1) 掌握 使 用 PHP 处 理 表单 数据 的 程序 代码 。 
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(2) 使 处 理 表单 数据 的 用 户 界面 更 具 健壮 性 。 

实 训 要 求 

将 例 5-1 中 的 EX5-1a. php 页 面 另存 为 sx5-1. php, 请 对 其 补充 完善 。 当 单 击 “ 提 交 ” 按 
钮 后 ,车 用 户 未 输入 或 输入 错误 , 则 在 相应 控件 的 右边 显示 红色 的 提示 信息 。 此 时 ,页 面 仍 
能 显示 用 户 输入 内 容 。 

实 训 2 使 用 JavaScript 脚本 验证 表单 数据 


实 训 目的 

(1) 学 会 利用 JavaScript 脚本 验证 表单 数据 。 

(2) 比较 PHP 脚本 和 JavaScript 脚本 在 验证 表单 数据 方面 的 区 别 和 联系 。 
实 训 要 求 

(1) 创建 一 个 名 为 sx5-2a. php 的 网 页 ,初始 界面 如 图 5-6 所 示 。 
































学 号  [F 
姓名 E 一 
性 别 ”|O 男 OQ 女 
年 龄 RS | 
系 别 “| 清寺 二 系列 国 

喜欢 城市 “| 口 北 京 日 上海 日 广州 日 深圳 





























图 5-6 初始 界面 


(2) 使 用 JavaScript 脚本 , 按 表 5-1 所 示 验 证 用 户 输入 的 数据 ,车 验证 失败 则 用 对 话 框 
显示 错误 信息 。 

(3) 如 果 各 项 填写 正确 , 则 单 击 "提交 ”按钮 后 ,就 能 在 sx5-2b. php 页 面 显 示 相 应 信息 ， 
运行 结果 如 表 5-2 所 示 。 
































表 5-1 验证 数据 表 5-2 sx5-2b. php 运行 界面 
学 生 信息 控件 名 称 要 求 学 号 20160101 
学 导 i 学 号 不 能 为 空 姓名 张 三 
姓名 sname | 姓名 不 能 为 空 
性 别 ssex | 必须 选择 性 别 is 男 
年 从 站 必须 输入 年 龄 .年龄 年 龄 20 

ae i 
必须 为 1 一 2 位 整数 系 别 计算 机 系 
系 别 sdept 必须 选择 系 别 一 一 
喜欢 城市 | ”city[] ”| 必须 选择 城市 喜欢 城市 北京 广州 














实 训 3 会 话 超时 


实 训 目的 
(1) 掌握 Session 的 超时 期 限 。 
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(2) 掌握 会 话 变量 的 定义 和 访问 。 
实 训 要 求 
创建 一 个 名 为 sx5-3. php 的 网 页 , 当 装 载 页 面 时 ,就 能 将 你 的 学 号 、 姓 名 存 信 Session 




















中 ,并 能 显示 系统 的 当前 时 间 和 Session 的 内 容 , 规 定 Session 的 超时 期 限 为 1 分 钟 。 经 过 
1 分 钟 后 , 单 击 “ 演 示 ” 按 钮 时 ,页 面 又 能 显示 什么 ?运行 界面 如 图 5-7 所 示 。 
当前 时 间 162710 
第 1 个 会 话 变量 的 值 1 
第 2 个 会 话 变量 的 值 张 三 
图 5-7 运行 界面 


实 训 提 示 
(1) 创建 一 个 表单 ,并 在 表单 中 创建 表格 和 "演示 ”按钮 。 
(2) 输出 系统 的 当前 时 间 : 二 ? php echo date('H.:i:s') ? 二 。 











思考 与 练习 

一 、 填空 题 

1. 在 同一 个 表单 中 , 多 个 复 选 框 成 组 出 现 ,它们 的 名 称 要 设置 且 必 须 为 

形式 ,如 name 二 "xq[]", 而 $_REQUEST["xq"] 获 取 的 是 一 个 ( 填 

“value 值 ”/*“ 数 组 ”) 。 

2. Session 的 超时 期 限 默 认为 分 钟 ,将 超时 期 限 修改 为 1 分 钟 的 PHP 语句 
为 。 

3.， Session 中 的 会 话 变量 ,用 于 保留 浏览 器 的 信息 。 

二 、 简 答题 


1. 常用 的 页 面 跳 转 方式 有 哪些 ? 试 各 举 一 例 。 
2. 在 PHP 中 实现 会 话 的 主要 步骤 有 哪些 ? 








MySQL 是 当前 比较 流行 的 中 小 型 数据 库 管 理 系统 ,也 是 最 常用 的 一 种 与 PHP 结合 
应 用 的 数据 库 管 理 系统 。 本 章 重点 介绍 MySQL 数据 库 以 及 数据 库 对 象 的 创建 与 使 用 
方法 。 


By SHO® 


学 会 使 用 Navicat_Premium 创建 数据 库 和 表 。 
。 掌握 MySQL 数据 库 的 复制 方法 。 
。 学 会 使 用 Navicat_Premium 编辑 T-SQL 语句 。 
。 掌握 MySQL 存储 过 程 的 创建 和 调用 。 
。 掌握 MySQL 触发 器 的 创建 和 使 用 。 


6.1 MySQL 基础 知识 


6.1.1 MySQL 简介 


MySQL 是 一 个 中 小 型 关系 数据 库 管理 系统 ,开发 者 为 瑞典 MySQL AB 公司 。 由 于 其 
体积 小 .速度 快 ,总 体 成 本 低 ,尤其 是 开放 源码 这 一 特点 ,许多 中 小 型 网 站 选择 了 MySQL 作 
为 后 台数 据 库 系统 。 

与 其 他 大 型 数据 库 相 比 ,MySQL 也 有 一 些 不 足 之 处 ,但 是 这 些 丝毫 没有 减少 它 受 欢迎 
的 程度 。 对 于 一 般 的 个 人 用 户 和 中 小 型 企业 来 说 , MySQL 提供 的 功能 已 经 绰绰有余 ,而 且 
由 于 MySQL 是 开放 源码 软件 ,因此 可 以 大 大 降低 总 体 成 本 。 

MySQL 数据 库 的 特点 主要 体现 在 以 下 几 个 方面 。 

(1) 可 以 处 理 拥 有 上 千 万 条 记录 的 大 型 数据 库 。 

(2) 支持 多 线程 ,充分 利用 CPU 资源 。 











(3) 使 用 C 和 C++ 语言 编写 ,并 使 用 多 种 编译 器 进行 测试 ,保证 了 源 代码 的 可 移植 性 。 

(4) 支持 绝 大 多 数 操作 系统 ,包括 Linux、Windows、FreeBSD IBM AIX、HP-UX、Mac 
OS .OpenBSD .Solaris 等 。 

(5) 为 多 种 编程 语言 提供 了 API 函数 ,包括 C、C++、Eiffel,Java、 Perl,PHP,Python、 
Ruby 和 Tcl 等 。 

(6) 优化 的 SQL 查询 算法 ,可 有 效 地 提高 查询 速度 。 

(7) 提供 可 用 于 管理 ,检查 、 优 化 数据 库 操作 的 管理 工具 ,如 WampServer 自 带 的 
phpMyAdmin, Navicat_Premium, 


6.1.2 ”MySQL 数据 对 象 

数据 库 可 以 看 作 一 个 存储 数据 对 象 的 容器 ,在 MySQL 中 ,这 些 数据 对 象 包括 以 下 
几 种 。 

1. 表 

表 是 MySQL 中 最 主要 的 数据 对 象 ,是 用 来 存储 和 操作 数据 的 一 种 迎 辑 结构 。 表 由 行 
和 列 组 成 ,因此 也 称 为 二 维 表 。 

2. 视图 

视图 是 从 一 个 或 多 个 基本 表 中 导出 的 表 , 一 个 视图 总 对 应 着 一 个 select 语句 。 数 据 库 
中 只 存放 视图 的 定义 ,而 不 存放 视图 对 应 的 数据 ,这 些 数 据 仍 存放 在 导出 视图 的 基本 表 中 ， 
因此 视图 又 称 为 虚拟 表 。 当 基本 表 中 的 数据 发 生变 化 时 ,从 视图 中 查询 出 来 的 数据 也 随 之 
改变 ,对 视图 的 查询 .更 新 ,实际 上 是 对 基本 表 的 查询 .更 新 。 

3. 存储 过 程 

将 一 组 完成 特定 功能 的 SQL 语句 ,经 编译 后 存储 在 数据 库 中 ,就 形成 存储 过 程 。 用 户 
通过 指定 存储 过 程 的 名 字 来 执行 它 。 存 储 过 程 具有 输入 参数 和 输出 参数 ,输入 参数 用 于 接 
收 外 界 提 供 的 初 值 , 输 出 参数 用 于 向 外 界 输出 一 个 或 多 个 结果 值 。 而 存储 过 程 内 没有 
return 语句 。 存 储 过 程 独立 于 表 存 在 。 

4. 函数 

函数 与 存储 过 程 类 似 ,不 同 的 是 函数 只 有 输入 参数 ,没有 输出 参数 ,函数 体内 必须 有 一 
个 return 语句 ,用 于 返回 一 个 结果 值 。 

5. 触发 器 

触发 器 是 一 种 特殊 类 型 的 存储 过 程 , 也 是 提前 编译 好 的 SQL 语句 的 集合 。 存 储 过 程 通 
过 存储 过 程 名 字 被 直接 调用 ,而 触发 器 只 有 对 数据 表 实 施 插入 、 修 改 、 删 除 操作 时 才 被 自动 
调用 。 触 发 器 基于 一 个 表 创 建 ,主要 用 于 维护 表 的 完整 性 。 


6.1.3 MySQL 数据 类 型 


在 创建 表 的 列 时 ,必须 为 其 指定 数据 类 型 ,数据 类 型 决定 了 数据 的 取 值 范围 和 存储 格 
式 。MySQL 提供 了 丰富 的 数据 类 型 ,如 表 6-1 所 示 。 
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类 别 数据 类 型 所 占 字 节 数 取 值 范围 或 要 求 
bigint 8 二 2 一 2 一 1 
int 4 = 

整 型 - 
smallint 2 一 32768 ~ 32767 
tinyint 1 0~255 
decimal 

精确 数值 型 必须 指定 小 数位 数 
numeric 

肖 点 型 float 4 单 精度 型 ,精确 到 7 位 小 数位 
double 8 双 精 度 型 ,精确 到 15 位 小 数位 

位 型 bit 逻辑 型 ,只 能 取 0 或 1 

字符 型 char(n) 定 长 字符 型 ,长 度 n 为 1 一 255 ,必须 指定 长 度 
varchar(n) 变 长 字符 型 ,长 度 n 为 0 一 255 ,必用 
tinytext 最 大 长 度 为 255(2 一 1) 
text 最 大 长 度 为 65535(2' 一 1) 

让 mediumtext 最 大 长 度 为 2* 一 1 
longtext 最 大 长 度 为 2* 一 1 
date 格式 为 : 'yyyy-mm-dd 7 

_ time 格式 为 : 'hh:mm:ss' 

日 期 时 间 型 datetime 格式 为 : 'yyyy-mm-dd hh:mm:ss' 

year 格式 为 : "yyyy" 
注意 : 


(1) 定义 MySQL 表 结 构 时 ,无 论 何 种 类 型 ,长 度 都 指数 据 中 的 字符 个 数 ,每 个 字母 、 数 
字 和 汉字 都 为 ] 个 字符 。 

(2) char(Cn): 定 长 字符 型 ,n 为 长 度 , 取 值 为 1 一 255, 默 认为 1。 当 输入 字符 串 长 度 小 
于 给 定 长 度 时 , 则 在 串 的 尾部 添加 空格 补足 ; 当 输 入 字符 串 长 度 大 于 给 定 长 度 时 , 则 自动 截 
去 尾部 多 余 的 字符 。 

(3) varchar(n) : 变 长 字符 型 ,n 为 长 度 , 取 值 为 1 一 255, 默 认为 1。 当 输入 字符 串 长 度 
小 于 给 定 长 度 时 , 则 以 实际 字符 存储 。 


6.2 使 用 Navicat_Premium 创建 和 管理 数据 库 


MySQL 数据 库 常 用 的 管理 工具 有 ODNavicat _Premium; @WampServer 自 带 的 
phpMyAdmin。 本 书 只 讨论 Navicat_Premium 的 使 用 。 

Navicat_Premium 是 一 套数 据 库 管理 工具 ,结合 了 其 他 Navicat 成 员 的 功能 ,支持 单一 
程序 同时 连接 到 MySQL、MariaDB、SQL Server、SQLite、Oracle 和 PostgreSQL 数据 库 。 
Navicat_Premium 可 满足 现今 数据 库 管 理 系统 的 使 用 功能 ,包括 存储 过 程 .事件 .触发 器 、 函 
数 、 视 图 等 。 
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6.2.1 数据 库 的 创建 和 删除 


1. 创建 MySQL 数据 库 

【 例 6-1】 使 用 Navicat_Premium 创建 一 个 名 为 stu 的 用 户 数据 库 。 

(1) 打开 Navicat_Premium, 单 击 “ 连 接 ” 按 钮 ,选择 MySQL, 打 开 “ 新 建 连接 ”对 话 框 。 
输入 连接 名 为 admin, 单 击 “ 确 定 ” 按 钮 ,如 图 6-1 所 示 。 























入 Wy5QL - 新 建 连接 


第 规 | 高 级 |sst jssx arp | 








连接 名 





主机 名 或 IP 地 址 


























图 6-1 “新 建 连接 "对 话 框 
(2) 右 击 左 侧 连 接 树 上 的 admin, 在 弹出 的 快捷 菜单 中 选择 “打开 连接 ”。 
(3) 右 击 admin, 在 弹出 的 快捷 菜单 中 选择 “新 建 数 据 库 ”, 打 开 “ 新 建 数 据 库 ” 对 话 框 ， 
在 数据 库 名 中 输入 stu, 如 图 6-2 所 示 。 




















图 6-2 “新 建 数据 库 " 对 话 框 
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(4) 右 击 左 侧 连接 树 上 的 stu, 在 弹出 的 快捷 菜单 中 选择 “打开 数据 库 ”。 

2. 删除 MySQL 数据 库 

右 击 左 侧 连接 树 上 的 stu, 在 弹出 的 快捷 菜单 中 选择 “删除 数据 库 ”, 在 弹出 的 “确认 删 
除 ” 对 话 框 中 , 单 击 “ 删 除 ” 按 钮 即 可 。 

6.2.2 创建 数据 表 


【 例 6-2】 在 stu 数据 库 中 创建 student 表 、course 表 和 sc 表 , 如 表 6-2 一 表 6-4 所 示 。 


表 6-2 student 表 










































































sno sname SSeX Sage sdept 
95001 李 勇 男 20 CS 
95002 刘 晨 女 19 IS 
95003 王 名 女 18 MA 
95004 张 立 男 18 IS 
表 6-3 course 表 表 6-4 sc 表 
cno cname credit sno cno grade 
1 数据 库 系 统 原理 4 95001 1 92 
2 操作 系统 3 95001 2 85 
让 序 区 计 95001 3 88 
4 汇编 语言 3 
多 媒体 技术 95002 1 90 
6 PHP 网 络 编程 & 95002 3 80 
操作 步骤 如 下 。 


(1) 创建 student 表 的 结构 。 
@D 右 击 左 侧 连接 树 上 的 stu 中 的 “ 表 ”, 在 弹出 的 快捷 菜单 中 选择 "新建 表 ”。 在 表 结 构 
中 输入 student 表 中 各 列 的 列 名 和 类 型 ,如 图 6-3 所 示 。 


三 。 辐 新 建 目 保 存 易 另 存 为 | .至 添 加 栏 位 ?插入 栏 位 强 删 除 栏 位 
位 


























[ 寿 位 ”|[ 案 引 [外 键 ”|[ 钥 发 器 | 渤 项 | 注释 [sar 预览 | 

名 类 型 长 度 。 小数 点 | 不 是 null 
Psnd char 5 0 回 
snane char 3 0 
Ssex char 2 0 

| :age int 4 0 品 
:aet har 2 0 回 


6-3 student 表 结 构 


@ char、varchar 类 型 必须 由 用 户 指定 长 度 ,其 他 类 型 的 长 度 可 以 不 指定 ,由 系统 自动 
给 出 。 为 了 使 数据 表 中 的 汉字 不 乱码 ,在 定义 MySQL 表 结 构 时 ,字符 型 (char、varchar、 
text) 字 上段 的 “字符 集 ” 应 设置 为 utf8。 

@ 单 击 “ 保 存 " 按 钮 ,在 弹出 的 对 话 框 中 输入 表 名 student。 

注意 : MySQL 数据 库 的 表 名 不 能 出 现 汉字 ,但 列 名 可 以 包含 汉字 。 


(2) 向 student 表 输 入 记录 。 


右 击 左 侧 连接 树 上 的 stu>“ 表 ”>student, 在 弹出 的 快捷 菜单 中 选择 “打开 表 ”, 就 可 以 
向 student 表 输 入 记录 。 


(3) 按照 创建 student 表 的 方法 ,依次 创建 course 表 和 sc 表 。 其 中 ,course 表 和 sc 表 
的 结构 如 图 6-4 和 图 6-5 所 示 。 
































[和 [过 31 [外 如 [县 器 [ 沈 项 | 注释 「 相让。 [索引 [外 刍 [触发 器 | 迹 项 “|[ 注 和 
名 类 型 ”| 长 度 小数点 | 不 是 nul | | 各 类 型 。 长度 小 数 点 | 不 是 mall 
Peno char 2 0 回 _ sno char 5 0 回 
2 char 20 0 回 Jeno char 2 0 回 
eredit int 4 0 回 Perade int 4 0 回 | 
图 6-4 ”course 表 结 构 图 6-5 sc 表 结构 





6.2.3 数据 库 的 复制 


每 个 MySQL 数据 库 以 文件 夹 形式 保存 在 C:\wamp\bin\mysql\mysql5. 5. 24\data 
中 ,内 含 若 干 个 表 文 件 ,每 个 表 文 件 以 “ 表 名 ”十 “. frm” 命 名 。 

复制 数据 库 的 步骤 如 下 。 

(1) 在 Navicat_Premium 中 ,打开 要 复制 的 数据 库 。 

(2) 单 击 “ 查 询 ” 按 钮 , 单 击 “ 新 建 查询 ”按钮 ,打开 查询 编辑 器 。 

(3) 在 查询 编辑 器 中 ,对 每 个 表 输 入 以 下 语句 : 


alter table 表 名 ENGINE = MYISAM ROW_FORMAT = COMPACT; 


例如 ,在 复制 stu 数据 库 之 前 ,必须 输入 以 下 3 条 语句 , 见 图 6-6 。 





三 PP 运行 -加 停止 名 解 炎 | 名 新 建 室 载 入 国保 存 易 另 存 为 | 并 美化 SQL 四 导出 
| 查询 所 建 工具 | 查询 编辑 器 
1 alter table student ENGINE = MYISAM ROW FORMAT = COMPACT; 
2 alter table course ENGINE = MYISAM ROW FORMAT = COMPACT; 
3 alter table sc ENGINE = MYISAM ROW FORMAT = COMPACT; 





图 6-6 查询 编辑 器 
(4) 单 击 “运行 ?按钮 。 


(5) 进入 C:\wamp\bin\mysql\mysql5. 5. 24\data\ 数 据 库 名 ,观察 每 个 表 是 否 对 应 
.frm、. MYD、. MYI 3 个 文件 ,若是 ,就 可 以 复制 数据 库 了 。 





6.3 使 用 Navicat_Premium 编辑 T-SQL 语句 


6.3.1 编辑 T-SQL 语句 的 步 又 


编辑 T-SQL 语句 的 步骤 如 下 。 

(1) 在 Navicat_Premium 中 ,打开 要 访问 的 数据 库 。 

(2) 单 击 "查询 ?按钮 , 单 击 " 新 建 查询 ”按钮 ,打开 查询 编辑 器 。 
(3) 在 查询 编辑 器 中 ,输入 T-SQL 语句 ,如 图 6-7 所 示 。 
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三 上 > 运行 - 目 信 上 名 解释 | 名 新 建 训 载 入 国保 存 用 另存 为 
[可 i 和 蛙 工 具 ] 查 记 及 可可 | 

1 select * from student; 

2 select * from course; 

















图 6-7 输入 SQL 语句 

(4) 单 击 “运行 ?按钮 ,就 能 在 结果 栏 显 示 执 行 结 果 。 

6.3.2 使 用 局 部 变量 

1. 声明 局 部 变量 

格式 : 

declare 变量 名 类 型 

例如 : 

declare a,b int; 

说 明 : 

(1) declare 语句 必须 放 在 存储 过 程 或 函数 中 的 首部 。 

(2) 在 MySQL 中 ,被 声明 的 变量 或 形 参 不 得 以 @ 开 头 , 且 必 须 在 存储 过 程 或 函数 中 
使 用 。 

(3) 若 要 在 存储 过 程 或 函数 外 部 使 用 变量 , 则 变量 不 必 声 明 , 但 必须 以 @ 开 头 。 

(4) 在 MySQL 中 ,每 一 条 SQL 语句 以 ";" 作 为 结束 标志 。 

2. 使 用 set 为 局 部 变量 赋值 


格式 : 
set 变量 名 = 表达 式 [, 变 量 名 = 表达 式 ] 
例如 : 


set a= 50,b=100; 

3. 使 用 select into 为 局 部 变量 赋值 
格式 : 

select 表达 式 表 into 变量 名 表 ; 

例如 : 

select 50,100 into a,b; 

功能 : 将 50、100 分 别 赋 给 a、b。 

4. 输出 表达 式 的 值 

格式 : 

select 表达 式 表 ; 


例如 : 


Select a, b; 


【 例 6-3】〗 局 部 变量 的 定义 和 使 用 的 示例 。 


create PROCEDURE procl() 
begin 
declare a,b INT; 
set a= 50,b= 100; 
select a, b; 
end 


6.3.3 流程 控制 语句 


在 MySQL 中 ,if 语句 、case 表达 式 、while 语句 等 流程 控制 语句 必须 放 在 存储 过 程 或 函 
数 中 。 
1. 并 语句 
语法 格式 : 
if 条 件 then 
语句 块 1 
[else 
语句 块 2] 
end if 


【 例 6-4】 如 果 存 在 姓 * 刘 ?的 学 生 , 则 输出 姓 * 刘 ?学 生 的 信息 ;如 果 不 存 在 , 则 输出 * 没 
有 姓 刘 的 学 生 ”。 


create PROCEDURE proc2( ) 

begin 

if exists(select * from student where sname like ' 刘 名 ') then 
select * from student where sname like ' 刘 名 '; 

else 
select ' 没 有 姓 刘 的 学 生 '; 

end if; 

end 


2. case 表达 式 
语法 格式 1: 


case 
when 条 件 1 then 结果 1 
when 条 件 2 then 结果 2 


[else 结果 n] 
end 


语法 格式 2， 


case 测试 表达 式 
when 常量 1 then 结果 1 
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when 常量 2 then 结果 2 


[else 结果 n] 
end 


【 例 6-5】 查询 学 生 的 姓名 和 所 在 系 别 , 当 系 别 为 CS 时 ,显示 “计算 机 科学 系 ” 当 系 别 
为 IS 时 ,显示 “信息 系统 系 ” 当 系 别 为 MA 时 ,显示 “数学 系 ”。 


create PROCEDURE proc3( ) 

begin 

select sname, case sdept 
when 'CS' then ' 计 算 机 科学 系 ' 
when 'IS' then ' 信 息 系统 系 ' 
when 'MA' then ' 数 学 系 / 
end as sdept 

from student; 

end 


3. while 语句 

语法 格式 : 

while 条 件 do 
语句 块 


end while 


【 例 6-6】 求 100 以 内 的 自然 数 之 和 。 


create PROCEDURE proc4( ) 
begin 
declare i,s int; 
set i=1,s=0; 
while i<=100 DO 
set s=st+i; 
set i=i+1; 
end while; 
select ' 和 为 :',s; 
end 


注意 : 每 一 条 SQL 语句 以 “;” 作 为 结束 标志 ,end、end if、end while 后 面 也 要 加 分 号 。 


6.4 使 用 Navicat_Premium 创建 存储 过 程 


在 Navicat_Premium 中 创建 MySQL 存储 过 程 有 两 种 方法 : 一 种 是 使 用 查询 编辑 器 ; 
另 一 种 是 使 用 函数 向 导 。 

6.4.1 使 用 查询 编辑 器 创建 存储 过 程 

1. 使 用 查询 编辑 器 创建 存储 过 程 


create procedure 过 程 名 (in| out 形 参 名 类 型 ) 
begin 


语句 序列 
end 
说 明 : 
(1) in 表示 输入 参数 ,用 于 接收 外 界 提供 的 初 值 。 
(2) out 表示 输出 参数 ,用 于 向 外 界 输出 参数 值 。out 必须 放 在 in 的 后 面 。 
【 例 6-7】 在 数据 库 stu 中 创建 一 个 存储 过 程 proc5, 要 求 带 2 个 输入 参数 和 1 个 输出 参数 。 
操作 步骤 如 下 。 
(1) 打开 stu 数据 库 , 单 击 “ 查 询 ”>“ 新 建 查 询 ” 按 钮 ,打开 查询 编辑 器 。 
(2) 在 查询 编辑 器 中 输入 : 
create PROCEDURE proc5(in a int, in b int,out c int) 
begin 
setc=at+b; 
end 
(3) 单 击 "运行 "按钮 。 至 此 ,在 stu 中 的 “函数 "下 面 出 现 proc5。 
2. 使 用 查询 编辑 器 调用 存储 过 程 


call 存储 过 程 名 ( 实 参 ); 


例如 ,调用 存储 过 程 proc5 的 步骤 如 下 。 

(1) 在 查询 编辑 器 中 输入 : 

call proc5(5,6, @result); 

select @result; 

(2) 单 击 "运行 "按钮 。 

注意 : 给 出 参数 对 应 的 实 参 必须 为 局 部 变量 。 

【 例 6-8】 在 数据 库 stu 中 创建 一 个 带 参 存储 过 程 proc6 , 当 输入 一 个 学 生 姓名 时 , 若 该 
学 生存 在 , 则 输出 该 学 生 的 学 号 姓名、 性 别 、 年 龄 和 系 别 ; 若 该 学 生 不 存在 , 则 输出 * 查 无 此 
学 生 ”。 

创建 存储 过 程 时 ,在 查询 编辑 器 中 输入 : 


create PROCEDURE proc6( in x char(3) character set gbk) 
begin 








if exists(select * from student where sname = x) then 
select #* from student where sname = x; 

else 
select ' 查 无 此 学 生 '; 

end if; 

end 


注意 : 当 形 参 类 型 为 char、varchar 时 ,一 般 在 类 型 后 面 加 入 character set gbk ,以 免 传 
递 汉字 出 现 乱码 。 
调用 存储 过 程 时 ,在 查询 编辑 器 中 输入 : 


call proc6( ' 刘 晨 '); 
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6.4.2 使 用 函数 向 导 创 建 存储 过 程 

1. 使 用 函数 向 导 创建 存储 过 程 

【 例 6-9】 在 数据 库 stu 中 创建 一 个 存储 过 程 proc7 ,功能 是 从 3 个 数 中 求 出 最 大 值 ,要 
求 带 3 个 输入 参数 。 

操作 步骤 如 下 。 

(1) 打开 stu 数据 库 , 单 击 顶部 的 “函数 ”一 “新 建 函 数 ” 按 钮 。 

(2) 在 “函数 向 导 ” 对 话 框 中 , 单 击 “ 过 程 ”按钮 ,打开 男 一 个 “函数 向 导 ” 对 话 框 ,如 图 6-8 
所 示 , 在 其 中 输入 3 个 参数 ,如 图 6-9 所 示 。 


请 输入 这 个 例 程 的 参数 


述 
模式 :如果 在 过 ; 上 
值 的 子 集 ， 博 寺 择 模式 . 


龟 指定 参数 的 名 。 此 为 必要 栏 
类 型 .限制 可 接受 值 的 类 型 。 此 
为 必要 栏 位 。 


























图 6-8 “函数 向 导 " 对 话 框 


请 输入 这 个 例 程 的 参数 





描述 

模式 - 加 果 在 过 程 中 参数 将 返回 
值 的 子 集 ， 本 

名 : 指定 参数 的 名 。 此 为 必要 栏 
位 。 


类 型 限制 可 接受 值 的 类 型 。 此 
为 必要 栏 位 。 





-人 个» 








下 次 显示 向 导 














(3) 单 击 “ 完 成 "按钮 ,弹出 定义 界面 。 在 begin 和 end 之 间 输 入 代码 ,如 图 6-10 所 示 。 


三 。 名 新 建 国保 存 钨 另存 为 | > 运行 看 售 上 | Q 查找 可 自动 换行 
定义 [高 级 [注释 [sar 预览 | 

1 HBEGIN 

2 DECLARE max float; 
e] if a>b then 

4 Set max=a; 

5 else 
6 
及 
8 











Set max=b; 
end IF; 
if c>max THEN 
9 Set max=c; 
10 end if; 
11 select ' 最 大 值 为 :' ,maxi| 





























12 上 END 

参数 i whosem do e fo 

返回 类 型 

类 型 mm 图 








图 6-10 定义 界面 


(4) 单 击 “ 保 存 ” 按 钮 ,打开 “过 程 名 ”对 话 框 ,在 其 中 输入 proc7, 如 图 6-11 所 示 。 单 击 
“确定 ”按钮 ,至 此 ,在 stu 中 的 “函数 ”下 面 出 现 proc5。 


输入 过 程 名 


proc?| 

















图 6-11 “过 程 名 "对话 框 


2. 查看 和 修改 存储 过 程 


例如 ,查看 proc7 的 操作 步骤 如 下 。 可 国 


田 围 表 


(1) 展开 左 侧 连接 树 上 的 stu->* 函 数 "~proe7, 右 击 proc7, 弹 。 时 ma 


出 如 图 6-12 所 示 的 快捷 菜单 。 

(2) 单 击 “ 设 计 函 数 ” 命 令 , 这 时 ,显示 如 图 6-10 所 示 的 定义 
界面 。 

3. 使 用 菜单 方式 运行 存储 过 程 

例如 ,运行 proc7 的 操作 步骤 如 下 。 

(1) 展开 左 侧 连接 树 上 的 stu>“ 函 数 ”>proc7, 右 击 proc7, 弹 
出 如 图 6-12 所 示 的 快捷 菜单 。 

(2) 单 击 “运行 函数 "命令 ,打开 “参数 " 对 话 框 ,在 其 中 输入 参 6-12 ”快捷 菜单 
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6-13 “参数 ”对话 框 


(3) 单 击 “ 确 定 ” 按 钮 ,得 到 运行 结果 。 
注意 ; 使 用 菜单 方式 运行 的 存储 过 程 ,存储 过 程 只 能 包含 输入 参数 ,不 能 包含 输出 
参数 。 


6.5 使 用 Navicat_Premium 创建 触发 器 


触发 器 是 一 种 特殊 类 型 的 存储 过 程 ,也 是 提前 编译 好 的 SQL 语句 的 集合 。 存 储 过 程 通 
过 存储 过 程 名 字 被 直接 调用 ,而 触发 器 只 有 对 数据 表 实 施 插 入 、 修 改 、 删 除 操作 时 才 被 自动 
调用 。 


6.5.1 触发 器 的 分 类 


触发 器 基于 一 个 表 创建 ,主要 用 于 维护 表 的 完整 性 。 和 触发 器 可 以 分 为 两 类 。 

(1) after 触发 器 : 当 对 表 实 施 插入 、 删 除 或 修改 操作 以 后 ,就 自动 触发 after insert、 
after delete 或 after update 触发 器 。 一 个 表 只 能 建立 一 个 after insert .一 个 after delete 、 一 
个 after update 触发 器 。 

(2) before 触发 器 : 当 对 表 实施 插 和 人 、 删 除 或 修改 操作 之 前 ,就 自动 触发 before insert、 
before delete 或 before update 触发 器 。 一 个 表 只 能 建立 一 个 before insert 、 一 个 before 
delete 一 个 before update 触发 器 。 


6.5.2 创建 和 使 用 触发 器 
1. 使 用 查询 编辑 器 创建 触发 器 


create trigger 触发 器 名 before|after 触发 事件 

i or 00 ON 

begin 

SQL 语句 序列 

End 

注意 : 

(1) 触发 事件 是 指 insert、update、delete 中 的 一 个 或 多 个 。 

(2) 当 执 行 insert 语句 后 ,就 自动 触发 after insert 触发 器 。 在 触发 器 中 ,新 记录 用 new 
(3) 当 执 行 delete 语句 后 ,就 自动 触发 after delete 触发 器 。 在 触发 器 中 ,被 删 记 录用 
old 表示 。 


(4) 当 执 行 update 语句 后 ,就 自动 触发 after update 触发 器 。 在 触发 器 中 ,被 删 记录 用 


old 表示 ,新 记录 用 new 表示 。 


(5) 在 语句 序列 中 ,不 允许 使 用 select 语句 返回 结果 集 ,也 不 允许 使 用 COMMIT 和 


ROLLBACK 语句 。 


【 例 6-10】 在 student 表 中 创建 一 个 after 触发 器 ,要 求 每 次 从 student 表 中 删除 一 个 
学 生 记录 时 ,就 自动 删除 sc 表 中 该 学 生 的 选课 记录 。 





操作 步骤 如 下 。 


(1) 打开 stu 数据 库 , 单 击 * 查 询 ” 一 “新 建 查询 "按钮 ,打开 查询 编辑 器 。 


(2) 在 查询 编辑 器 中 输入 : 


create trigger trigl after delete 


on student for each row 
begin 


delete from sc where sno= old. sno; 


End 


(3) 单 击 “运行 ?按钮 。 
2. 查看 和 修改 触发 器 


例如 ,查看 student 下 的 trigl 触发 器 的 操作 步骤 如 下 。 
(1) 展开 左 侧 连 接 树 上 的 stu-> 表 ”一 student , 右 击 student。 
(2) 从 弹出 的 快捷 菜单 中 选择 “设计 表 ”, 显 示 * 栏 位 ”选项 卡 。 单 击 “ 触 发 器 ”选项 卡 , 如 


图 6-14 所 示 。 





三 号 新 建国 保存 易 另 存 为 | 和 0 添加 般 发 器 ?@ 删 除 甬 发 器 














[ 栏 位 |[ 案 引 [外 键 | 用 发 器 [选项 [注释 |sar 预览 | 

名 触发 插入 更 新 贡 除 
Ptriel After 口 口 
定义 











begin 
delete from se where sno=old sno; 
End 





3. 触发 触发 器 


图 6-14 “触发 器 "选项 卡 


例如 , 当 删 除 student 中 学 号 为 95001 的 学 生 时 ,将 触发 trigl 触发 器 


如 下 。 


(1) 打开 stu 数据 库 , 单 击 “ 查 询 ”>“ 新 建 查询 ”按钮 ,打开 查询 编辑 器 。 


(2) 在 查询 编辑 器 中 输入 : 


delete from student where sno= '95001 7 


(3) 单 击 “运行 ?按钮 。 
4. 删除 触发 器 


例如 ,删除 student 下 的 trigl 触发 器 的 操作 步骤 如 下 。 


。 其 操作 步骤 


(1) 打开 如 图 6-14 所 示 的 “触发 器 ”选项 卡 。 
(2) 选择 要 删除 的 触发 器 trigl。 
(3) 单 击 “删除 触发 器 ?按钮 。 


6.6 项 目 实 训 


实 训 1 


实 训 目 的 


MySQL 数据 库 和 表 的 创建 


(1) 学 会 使 用 Navicat_Premium 创建 数据 库 和 表 。 
(2) 掌握 MySQL 数据 库 的 复制 方法 。 


实 训 要 求 


(1) 使 用 Navicat_Premium 创建 一 个 名 为 library 的 数据 库 , 并 在 library 数据 库 中 创建 


book 表 、reader 表 和 borrow 表 , 如 图 6-15 一 图 6-17 所 示 。 


书籍 TD | 书 名 出 版 社 作者 姓名 ”在 馆 数量 
» 1001 心灵 鸡汤 人 民 出 版 社 刘 塘 5 
1002 数字 逻辑 教育 出 版 社 兰 10 
1003 风云 对 话 文学 出 版 社 李 兴 10 
1004 人 工 智能 教育 出 版 社 陈 思 楷 10 
1005 居 里 夫人 人 民 出 版 社 钟 福 德 10 
1006 科学 的 故事 “光明 出 版 社 。“ 姚 夸 5 
1007 宁 词 三 百 首 。 ”教育 出 版 社 陈 冬 立 5 
1008 唐诗 三 百 首 。 ”教育 出 版 社 。 刘 凯 森 10 
图 6-15 book 表 
读者 ID ”读者 姓名 联系 电话 家庭 住址 
上 1 陈 里 媚 886954 ”安平 路 22 号 
2 张 素 娇 887541 跃进 路 4 号 
3 林 裔 896521 玫瑰 园 4 栋 302 
副 4 吴启华 874596 ”金币 花园 5 栋 
5 周 慧 875112 昌平 街 3 号 
6 方 玲 879698 同 平 路 7 号 
6-16 ”reader 表 
借阅 编号 书籍 ID ”读者 ID “ 借 书 日 期 还 书 日 期 
»3000| 1001 2 2016-04-02 2016-05-06 
13001 1005 5 2016-04-03 2016-04-25 
_3002 1005 2 2016-04-03 2016-04-14 
_3003 1008 1 2016-04-04 2016-05-08 
_3004 1004 6 2016-04-11 2016-05-02 
3005 1007 2 2016-04-12 2016-05-26 
3006 1003 3 2016-04-12 2016-05-27 
图 6-17 borrow 表 


(2) 为 library 数据 库 做 好 复制 前 的 准备 。 


实 训 2 使 用 MySQL 编写 TSQL 程序 


实 训 目的 

(1) 学 会 编辑 T-SQL 语句 的 操作 方法 。 

(2) 掌握 局 部 变量 的 定义 和 使 用 。 

(3) 掌握 过 语 句 、case 表达 式 、while 语句 。 

实 训 要 求 

已 知 局 部 变量 a 一 12,b 一 100,c 一 8, 在 查询 编辑 器 中 编写 2 个 程序 ,功能 分 别 如 下 。 
(1) 输出 a、b.c 的 最 大 者 。 

(2) 将 a\b'\c 的 值 由 小 到 大 排列 。 


实 训 3 ”MySQL 存储 过 程 的 创建 和 调用 


实 训 目的 

(1) 掌握 MySQL 存储 过 程 的 创建 。 

(2) 掌握 MySQL 存储 过 程 的 查看 和 修改 。 

(3) 掌握 MySQL 存储 过 程 的 调用 。 

实 训 要 求 

根据 library 数据 库 , 创 建 如 下 存储 过 程 。 

(1) 创建 一 个 无 参 存储 过 程 procl ,功能 是 返回 读者 “ 陈 里 媚 ” 所 购 图 书 的 名 称 、 出 版 社 、 
作者 和 在 馆 数 量 。 试 运行 一 次 存储 过 程 。 

(2) 创建 一 个 带 参数 的 存储 过 程 proc2 ,要 求 : 当 用 户 输入 书籍 的 ID 时 ,就 对 该 书籍 的 
在 馆 数量 进行 判断 。 当 在 馆 数量 大 于 10 时 ,显示 “库存 满 "; 当 在 馆 数量 为 5 一 10 时 显示 
“充裕 ”; 当 在 馆 数量 小 于 5 时 ,显示 “库存 不 足 , 请 尽快 补 货 ”。 试 执行 一 次 存储 过 程 。 


实 训 4 MySQL 触发 器 的 创建 和 应 用 


实 训 目的 

(1) 掌握 MySQL 触发 器 的 创建 。 

(2) 掌握 MySQL 触发 器 的 查看 和 修改 。 
(3) 掌握 MySQL 触发 器 的 触发 。 
实 训 要 求 


在 library 数据 库 的 book 表 中 创建 一 个 after 触发 器 ,要 求 每 当 从 book 表 中 删除 一 条 
书籍 记录 时 ,就 自动 删除 borrow 表 中 该 书籍 的 借阅 记录 。 


思考 与 练习 





一 、 填空 题 
1. 存储 过 程 通过 被 直接 调用 ,存储 过 程 表 存在 。 而 触发 器 只 对 数据 


表 实 施 操作 时 才 被 自动 调用 .触发 器 存在 。 

2. 定义 MySQL 表 结 构 时 ,无 论 何 种 类 型 ,长 度 都 指数 据 中 的 字符 个 数 ,每 个 字母 、 数 
字 和 汉字 分 别 为 个 字符 。 

3. 当 执行 insert 语句 后 ,就 自动 触发 after insert 触发 器 。 在 触发 器 中 ,新 记录 
用 表示 。 

4. 当 执 行 delete 语句 后 ,就 自动 触发 after delete 触发 器 。 在 触发 器 中 ,被 删 记 录 
用 表示 。 

二 、 简 答 题 

1. MySQL 对 declare 语句 的 使 用 场合 有 什么 要 求 ? 

2. 存储 过 程 的 特点 有 哪些 ?” 如何 创 建 MySQL 存储 过 程 ? 

3. 当 执 行 update 语句 后 ,就 自动 触发 哪个 触发 器 ? 在 触发 器 中 ,被 删 记 录用 什么 表 
示 ? 新 记录 用 什么 表示 ? 





MySQL 是 当前 比较 流行 的 中 小 型 数据 库 管理 系统 ,也 是 最 常用 的 一 种 与 PHP 结合 应 
用 的 数据 库 管理 系统 。 本 章 将 讨论 PHP 访问 MySQL 数据 库 的 流程 方法 。 


CE) ooee 


。 了 解 PHP 访问 MySQL 的 基本 流程 。 
。 掌握 数据 表 的 增 、 删 \ 改 方法 。 
。 学 会 将 数据 表 以 表格 形式 显示 在 网 页 的 方法 。 


7.1 PHP 访问 MySQL 的 基本 流程 
使 用 PHP 访问 MySQL 数据 库 , 必 须 让 PHP 程序 先 连 接 MySQL 服务 器 ,再 选择 一 个 


数据 库 , 然 后 向 MySQL 数据 库 管 理 系 统 发 送 SQL 语句 ,其 基本 流程 如 图 7-1 所 示 。 


连接 MySQL 服 务 器 


| 


选择 数据 库 
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发 送 SQL 语 句 


teeeily eee 


执行 被 影响 结果 集 
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图 7-1 PHP 访问 MySQL 流程 


如 果 发 送 的 是 insert delete 或 update 等 SQL 语句 ,MySQL 执行 完成 并 对 数据 表 的 记 
录 有 所 影响 ,说 明 执 行 成 功 。 如 果 发 送 的 是 select 语句 ,会 返回 结果 集 , 还 需要 对 结果 集 进 
行 处 理 。 处 理 结 果 集 又 包括 获取 记录 数据 和 获取 字段 信息 ,而 多 数 情况 下 只 需要 获取 记录 
数据 即 可 。 脚 本 执行 结束 后 还 需要 关闭 本 次 连接 。 

7.1.1 连接 MySQL 服务 器 

在 PHP 中 ,用 于 连接 MySQL 服务 器 的 函数 是 mysql_connect() ,语法 格式 如 下 : 

连接 对 象 = mysql_connect( 服 务 器 名 ,用 户 名 , 密码 ) 

说 明 : 

(1) 服务 器 名 指定 要 连接 的 MySQL 服务 器 ,例如 ,127. 0. 0. 1 \localhost 等 。 服 务 器 名 
还 可 以 包括 端口 号 ,例如 ,localhost:3306( 其 中 3306 为 MySQL 的 默认 端口 号 ) 。 

(2) 用 户 名 指定 连接 所 使 用 的 用 户 名 ,例如 ,root。 

(3) 密码 指定 连接 所 使 用 的 密码 ,默认 为 ""。 

例如 : 


$ con = mysql_connect( 'localhost', ‘root', ''); 


【 例 7-1】 测试 能 否 连 接 MySQL 服务 器 。 
创建 EX7-1. php 网 页 ,输入 以 下 代码 。 


<?php 
$ con = mysql_connect( 'localhost', 'root', ''); 
if( $ con) echo "连接 成 功 "; 
else echo "连接 失败 "; 
> 
7.1.2 选择 数据 库 
连接 到 服务 器 后 ,需要 使 用 mysql_select_db() 函数 选择 数据 库 ,语法 格式 如 下 ， 
mysql_select_db( 数 据 库 名 [, 连 接 对 象 ]) 
例如 ,选择 数据 库 stu 的 语句 为 : 


mysql_select_db( 'stu'") 
7.1.3 执行 SQL 语句 
在 PHP 中 ,使 用 mysql_query( 〇 函数 执行 SQL 语句 ,语法 格式 如 下 : 


结果 集 = mysql_query( "select 语句 ") 
布尔 变量 = mysql_query(" 非 select 语句 ") 


【 例 7-2】 编写 程序 ,向 student 表 插 入 一 条 新 记录 (95006, 李 光荣 , 男 ,21,CS)。 
创建 EX7-2. php 网 页 ,输入 以 下 代码 。 





<?php 
$ con = mysql_connect( 'localhost', ‘root', ''); 


mysql_select_db( 'stu'); 
mysql_query("set names utf8"); // 设 置 字符 集 为 utf8 
$ sql = "insert into student values( '95006', ' 李 光荣 ', ' 男 ',21, 'CS ')"; 
$2zt=mysql_query( $ sql); 
if ($zt) echo "插入 成 功 !"; 
?> 
注意 : 中 文 数据 在 插入 时 可 能 出 现 乱码 ,解决 办 法 是 : 首先 要 保证 页 面 设置 的 字符 集 
和 数据 库 的 字符 集 一 致 ,要 么 都 是 utf8, 要 么 都 是 gb2312。 然 后 ,在 执行 SQL 语句 的 前 面 
加 入 mysql_query("set names utf8") ;或 mysql_query("set names gb2312");。 


7.1.4 关闭 连接 


当 一 个 已 经 打开 的 连接 不 再 需要 时 ,可 以 使 用 mysql_close( ) 函 数 将 其 关闭 ,语法 格式 
如 下 : 


mysql_close( [连接 对 象 ]) 


如 果 省 略 连接 对 象 , 则 关闭 上 一 个 打开 的 连接 。 这 时 通常 不 需要 使 用 mysql_close() 函 
数 ,因为 已 打开 的 连接 会 在 脚本 执行 完毕 后 自动 关闭 。 


7.2 处理 结果 集 


使 用 mysql_query() 函 数 执行 select 语句 后 ,会 返回 一 个 结果 集 。 需 要 使 用 特殊 函数 才 
能 从 结果 集中 获取 记录 。 


7.2.1 从 结果 集中 获取 记录 
1. mysql_fetch_row( ) 函 数 
格式 : 

数组 名 = mysql_fetch_row( 结 果 集 ) 


功能 : 从 结果 集中 逐 行 获取 记录 ,并 将 每 一 行 记录 存 和 一 维 数组 中 ,数组 的 键 名 为 整数 
键 名 。 

【 例 7-3】〗 将 student 表 以 表格 形式 显示 在 网 页 中 。 

(1) 创建 EX7-3. php 网 页 ,在 Dreamweaver 的 设计 视图 制作 一 个 2 行 5 列 的 表格 。 

(2) 切换 到 代码 视图 ,输入 PHP 脚本 。 整 个 网 页 的 代码 如 下 : 


<?php 
$ con = mysql_connect( 'localhost', ‘root', ''); 
mysql_select_db( 'stu'); 
mysql_query( "set names utf8"); // 设 置 字符 集 为 utf8 
$sql="select * from student"; 
$result =mysql_query( $ sql); 

?> 

< table width = "400" border = "1" align = "center" cellpadding = "0"> 
<tr> 





<td height = "30" align = "center"> 学 号 </td> 
<td height = "30" align = "center"> 姓 名 </td> 
<td height = "30" align = "center"> 性 别 </td> 
<td height = "30" align = "center"> 年 龄 </td> 
<td height = "30" align = "center"> 系 别 </td> 

</tr> 

<?php 
$ row = mysql_fetch_row( $ result); 
while( $ row) 


{ 


?> 
<tr> 
<td height = "30" align = "center"><?php echo $ row[0];?></td> 
<td height = "30" align = "center"><?php echo $ row[1];?></td> 
<td height = "30" align = "center"><?php echo $ row[2];?></td> 
<td height = "30" align = "center"><?php echo $ row[3];?></td> 
<td height = "30" align = "center"><?php echo $ row[4];?></td> 
</tr> 
<?php 


$ row = mysql_fetch_row( $ result); 
} 


?> 
</table> 


2. mysql_fetch_assoc() 函 数 
格式 : 
数组 名 = mysql_fetch_assoc( 结 果 集 ) 


功能 ; 从 结果 集中 逐 行 获取 记录 ,并 将 每 一 行 记录 存 人 一 维 数组 中 ,数组 的 键 名 为 字段 
名 或 别名 。 

注意 : 如 果 给 字段 起 别名 ,那么 数组 的 键 名 必须 为 别名 。 

【 例 7-4】 将 student 表 中 第 一 个 学 生 的 学 号 、 姓 名 输出 。 

创建 EX7-4. php 网 页 ,输入 以 下 代码 。 


<?php 
$ con = mysql_connect( 'localhost', ‘root', ''); 
mysql_select_db( 'stu'); 
mysql_query( "set names utf8"); // 设 置 字符 集 为 utf8 
$ sql =" select sno as 学 号 , sname from student"; 
$result =mysql_query( $ sql); 
$ row= mysql_fetch assoc( $ result); 
echo $ row[" 学 号 "]; // 不 能 写成 $ row[ "sno"] 
echo $ row["sname"]; 

?> 


3. mysql_fetch_array() 函 数 
格式 : 


数组 名 = mysql_fetch_array( 结 果 集 ) 


功能 : 从 结果 集中 逐 行 获取 记录 ,并 将 每 一 行 记录 存 人 一 维 数组 中 ,数组 的 键 名 可 以 是 
整数 和 字段 名 。 


4. mysql_fetch_object() 函 数 
格式 : 
对 象 名 = mysql_fetch_object( 结 果 集 ) 


功能 : 从 结果 集中 逐 行 获取 记录 ,并 将 每 一 行 记录 存 人 


如 下 : 


对 象 名 - > 字段 名 


对 象 中 。 对 象 的 某 个 字段 表示 


【 例 7-5】 将 student 表 中 第 一 个 学 生 的 学 号 、 姓 名 输出 。 


创建 EX7-5. php 网 页 ,输入 以 下 代码 。 


<?php 
$ con = mysql_connect( localhost', 'root ', ''); 
mysql_select_db( 'stu'); 
mysql_query( "set names utf8"); // 设 置 字符 集 为 utf8 
$ sql = "select sno, sname from student"; 
$result =mysql_query( $ sql); 
$ row = mysql_fetch_object( $ result); 
echo $ row 一 > sno; 
echo $ row 一 > sname; 
?> 


7.2.2 其 他 MySQL 函数 

1. mysqLnum_rows() 函 数 

格式 : 

变量 名 = mysql_num_rows( $ result) 

功能 : 获取 结果 集 $ result 中 行 的 数目 。 
2. mysql_num_fields( ) 函 数 

格式 : 

变量 名 = mysql_num_fields( $ result) 

功能 : 获取 结果 集 $ result 中 字段 的 数目 。 
3. mysqlL_field_name() 函 数 

格式 : 

字符 串 变量 = mysql_field_name( $ result, $ i) 


功能 : 获取 结果 集 $ result 中 序号 $i 的 字段 名 。 


【 例 7-6】〗 创建 一 个 名 称 为 EX7-6. php 的 网 页 ,要求 在 页 面 中 添加 一 个 下 拉 框 ,用 户 从 





下 拉 框 中 任 选 一 个 数据 表 , 该 数据 表 就 以 表格 形式 显示 在 网 页 中 。 
(1) 在 Dreamweaver 的 设计 视图 中 制作 一 个 下 拉 框 和 一 个 包含 1 行 1 列 的 表格 。 相 应 
的 HTML 代码 如 下 : 


<center> 
< form id = "forml" name = "forml" method= "post" action= ""> 
< select name = "select"> 
<option value = ""> 请 选择 一 个 表 </option > 
<option > student </option > 
<option > sc </option> 
<option > course </option> 


</select > 
< input type = "submit" name = "Submit"” value = "确定 " /> 
</form> 
</center > 
<table width= "400" border = "1" align= "center" cellpadding = "0"> 
<tr> 
<td> gnbsp;</td> 
</tr> 
</table> 
(2) 切换 到 代码 视图 ,把 二 table 二 与 之 /table 二 之 间 的 代码 改写 成 如 下 PHP 脚本 。 
<?php 


if (isset( $ _REQUEST[ "Submit"])) 
{ 
$ bm= $ _REQUEST["select"]; 
$ con = mysql_connect( 'localhost', 'root', ''); // 连 接 服务 器 
mysql_select_db( 'stu’, $ con); // 选 择 数 据 库 
mysql_query( "SET NAMES utf8"); 
$sql="select * from $ bm"; 
$ result = mysql_query( $ sql); // 执 行 SQL 语句 
$ row = mysql_fetch_row( $ result); 
echo "< table width= '400' border = '1'align= 'center' cellpadding= '0 >"; 
echo "<tr>"; 
for ($i=0; $i<mysql_num fields( $ result); $ i++) 
echo "< td align = 'center' height = '30'>".mysql_field_name( $ result, $i)."</td>"; 
echo "</tr >"; 
while( $ row) 
{ 
echo "<tr>"; 
for ($i=0; $i<mysql_num fields( $ result); $ i++) 
echo "<td align= 'center ' height = '30'>". $ row[ $i]."</td>"; 
echo "</tr >"; 
$ row= mysql_fetch_row( $ result); 
} 
echo "</table >"; 


?> 


7.3 结果 集 的 分 页 


1. 分 页 显示 的 原理 

所 谓 分 页 显示 ,就 是 将 数据 表 中 的 结果 集 人 为 地 分 成 一 段 一 段 来 显示 ,工作 流程 如 下 。 
(1) 获取 结果 集 的 记录 总 条 数 $ count 。 

(2) 规定 每 页 要 显示 的 记录 条 数 $ pagesize, 算 出 总 页 数 $ pagecount。 


if ( $count% $ pagesize== 0) $ pagecount = $ count/ $ pagesize; 
else $ pagecount = (int)( $ count/ $ pagesize+ 1); 


(3) 规定 当前 要 显示 的 页 数 $currentpage。 
首先 显示 结果 集 的 第 1 页 , 当 用 户 单 击 “ 首 页 “上 一 页 “下 一 页 “ 尾 页 ”的 超 链接 时 ,就 
显示 相应 的 页 数 。 


$ page = @ $ _REQUEST[ "page" ]; 
if ( $ page== null) $ currentpage= 1;else $ currentpage = intval( $ page); 


(4) 显示 当前 页 的 所 有 记录 。 
2. 实例 


【 例 7-7】 创建 一 个 名 称 为 EX7-7. php 的 网 页 ,要求 分 页 显示 teacher 表 中 的 记录 , 设 
计 界 面 如 图 7-2 所 示 。 
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图 7-2 设计 界面 


若 当前 显示 第 1 页 , 则 “首页 “上 一 页 "不 显示 超 链 接 ; 若 当 前 显示 最 后 一 页 , 则 “下 一 
页 ”“ 尾 页 ”不 显示 超 链接 ; 规定 每 页 显示 20 条 记录 。 
程序 代码 如 下 : 


<?php 
$ con = mysql_connect( 'localhost', 'root', ''); 
mysql_select_db( 'stu'); 
mysql_query( "set names utf8"); // 设 置 字符 集 为 utf8 
$sql="select * from teacher"; 
$ result =mysql_query( $ sql); 
$ count = mysql_num_rows( $ result); // 记 录 总 条 数 $ count 


$ pagesize = 20; // 每 页 要 显示 的 记录 条 数 $ pagesize 

if ( $count% $ pagesize == 0) $ pagecount = $ count/ $ pagesize; else $ pagecount = (int) 
( $ count/ $ pagesize + 1); // 总 页 数 $ pagecount 

$ row = mysql_fetch_assoc( $ result); // 数 组 $ row 的 键 名 为 字段 名 

$ page = @ $ _REQUEST[ "page"]; // 欲 显示 的 页 数 $ page 


if ($ page== null) $ currentpage= 1;else $ currentpage= intval( $ page); 
for($i=1;$i<=($currentpage -1)* $ pagesize; $i++)  // 规 定 每 一 页 面 显示 20 条 记录 
{ 证 (! $ row) break; 





$ row = mysql_fetch assoc( $ result); 


} 
?> 
<table width= "500" border ="1" align = "center" cellpadding = "0"> 
<tr> 
< td height = "25" colspan = " 5" align = "center” bgcolor = " 间 99CCCc"> 第 < php echo 
$ currentpage;?> 页 / 共 <?php echo $ pagecount;?> 页 </font > gnbsp;&nbsp; 
<?php 
证 ($currentpage ==1) echo "首页 | 上 一 页 | "; 
else 
{?> 
<a href = "EX7 - 7.php?page = 1"> 首 页 </a> | 
<a href = "EX7 - 7. php?page = <?php echo $ currentpage 一 1;?>"> 上 一 页 </a> | 
php 
} 
if ( $ currentpage == $ pagecount) echo "下 一 页 | 尾 页 "; 
else 
{?> 
<a href = "EX7 - 7. php?page = <?php echo $ currentpage +1;?>"> 下 一 页 </a> | 
<a href = "EX7 — 7. php?page = <?php echo $ pagecount;?>"> 尾 页 </a> 
<?php 
} 
?></td> 
</tr> 
<tr> 
<td width= "100" height = "25" align = "center"> 职 工 号 </td> 
<td width = "100" height = "25" align = "center"> 姓 名 </td> 
<td width = "100" height = "25" align = "center"> 密 码 </td> 
<td width= "100" height = "25" align = "center"> 性 别 </td> 
<td width= "100" height = "25" align= "center"> 出 生日 期 </td> 
</tr> 
<?php 
for( $i=1;$i<= $ pagesize; $ i++) 
{ if (! $ row) break; 
?> 
<tr> 
<td width= "100" height = "25" align= "center"><?php echo $ row[" 职 工 号 "];?></td> 
<td width= "100" height = "25" align= "center"><?php echo $ row[" 姓 名 "];?></td> 
<td width= "100" height = "25" align = "center"><?php echo $ row[ "密码 "];?></td> 
<td width= "100" height = "25" align = "center"><?php echo $ row[" 性 别 "];?></td> 








<td width= "100" height = "25" align= "center"><?php echo $ row[" 出 生日 期 "];?></td> 
</tr> 
<?php 
$ row = mysql_fetch_assoc( $ result); 
} 
?> 


</table> 


7.4 项 目 实 训 


实 训 1 对 数据 表 进 行 插 人 操作 


实 训 目的 


(1) 掌握 使 用 PHP 脚本 验证 表单 数据 的 方法 。 

(2) 掌握 向 数据 表 插 入 记录 的 方法 。 

实 训 要 求 

在 sx7 目录 下 创建 sx7-1. php 网 页 ,设计 界面 如 图 7-3 所 示 , 请 对 library 库 中 的 book 
表 进 行 操 作 , 要 求 ， 

(1) 使 用 PHP 脚本 验证 用 户 是 否 输入 数据 ,对 于 "书籍 ID” 在 馆 数 量 ” 还 要 验证 用 户 
输入 的 数据 是 否 正确 。 若 "书籍 ID” 与 book 表 中 原 有 的 “书籍 ID” 相 同 , 则 显示 “书籍 ID 已 
经 存在 ,请 重 输 !1” 的 提示 信息 ; 若 “ 在 馆 数 量 ” 为 非 整 数 , 则 显示 "在 馆 数 量 必须 为 整数 ”的 提 
示 信 息 。 

(2) 当 用 户 输入 的 数据 正确 并 单 击 “ 添 加 ”按钮 后 ,就 能 向 book 表 添 加 一 条 记录 ,并 弹 
出 “插入 成 功 1” 的 对 话 框 。 
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图 7-3 实 训 1 设计 界面 


实 训 2 将 指定 的 数据 表 以 表格 形式 显示 在 网 页 中 


实 训 目的 

(1) 学 会 从 结果 集中 逐 行 获取 记录 。 

(2) 学 会 在 HTML 标记 中 嵌入 PHP 脚本 。 

实 训 要 求 

在 sx7 目录 下 创建 sx7-2. php 网 页 ,功能 是 将 library 数据 库 中 的 book 表 以 表格 形式 
显示 在 网 页 中 。 


实 训 3 将 任意 一 个 数据 表 以 表格 形式 显示 在 网 页 中 


实 训 目的 
(1) 学 会 从 结果 集中 逐 行 获取 记录 。 


(2) 掌握 mysql_num_fields() .mysql_field_name() 函数 的 应 用 。 

实 训 要 求 

在 sx7 目录 下 创建 sx7-3. php 网 页 ,要 求 在 页 面 中 添加 一 个 下 拉 框 ,内 含 3 个 选项 : 
book 表 、reader 表 、borrow 表 , 用 户 从 下 拉 框 中 任 选 一 个 表 名 ,该 表 就 以 表格 形式 显示 在 网 
页 中 。 











思考 与 练习 

一 、 填空 题 

1. PHP 访问 MySQL 数据 表 的 4 个 基本 流程 是 
和 

人 Rate 的 默认 端口 号 是 ,MySQL 的 默认 端口 号 是 

3. 语句 $row 二 mysql_fetch_row( $result) 的 功能 是 : 从 结果 集 $ i 中 ， 
并 将 ” 存 和 人 一 维 数组 $row 中, $row 的 键 名 为  _ 键 名 。 


二 、 简 答题 

1. 将 指定 的 数据 表 ( 假 设 有 5 列 ) 以 表格 形式 显示 到 网 页 中 ,一 般 在 Dreamweaver 的 设 
计 视 图 中 要 先 制 作 一 个 几 行 几 列 的 表格 ? 

2. 将 任意 一 个 数据 表 以 表格 形式 显示 到 网 页 中 ,一 般 在 Dreamweaver 的 设计 视图 中 要 
先 制作 一 个 几 行 几 列 的 表格 ? 





PHP 为 我 们 提供 了 很 多 功能 模块 , 像 目录 与 文件 操作 .日 期 时 间 、` 图 形 处 理 等 。 这 些 最 
常用 的 功能 已 经 成 为 PHP 基础 语言 的 一 部 分 ,在 PHP 项 目 开发 时 经 常会 用 到 。 


GH eoee: 


。 掌握 目录 和 文件 的 创建 、 删 除 等 操作 。 

。 掌握 文件 的 打开 、 关 闭 、 写 入 、 读 取 等 操作 。 
。 掌握 日 期 和 时 间 函 数 的 使 用 。 

。 了 解 日 期 的 计算 和 检查 。 

。 掌握 图 形 的 创建 和 绘制 等 操作 。 


8.1 目录 与 文件 操作 


一 般 ,程序 中 的 数据 只 存储 在 内 存 中 ,程序 结束 时 数据 会 丢失 。 如 果 要 把 一 些 数据 存储 
起 来 ,就 要 使 用 文件 。 


8.1.1 目录 操作 


目录 可 以 看 作 一 个 文件 夹 。 在 网 页 中 ,一 般 用 /代表 站 点 所 在 的 目录 ; ./ 代 表 当 前 目 
录 , 即 当前 页 面 所 在 的 目录 ; ../ 代 表 当 前 目录 的 上 一 级 目录 。 例 如 ,在 图 8-1 所 示 的 目录 树 
中 ,要 在 1. php 页 面 中 表示 test 目录 的 路 径 为 ./; 表示 aa 日 国 站 点 -WPHF G:Aph .. 
目录 的 路 径 为 ../aa; 表示 chap08 目录 的 路 径 为 ../../ 国 shsz0l 


chap08 。 = 人 
en 2 
格式 : i 二 1.php 


mkdir(" 目 录 路 径 ") 图 8-1 目录 树 
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功能 : 创建 指定 的 目录 ,车 创建 成 功 则 返回 true; 否则 返回 false。 执 行 前 ,车 已 存在 指 
定 的 目录 , 则 报错 。 
【 例 8-1】 在 当前 目录 中 创建 test 目录 。 


<?php 
if(mkdir("test" )) echo "创建 成 功 !"; 
?> 
程序 解释 : 首先 创建 EX8-1. php 页 面 ,在 其 中 输入 上 面 代码 。 运 行 结果 是 ,在 EX8-1. 
php 页 面 所 在 目录 之 下 创建 一 个 新 目录 test。 
2. 删除 空 目录 
格式 : 
rmdir(" 目 录 路 径 "); 
功能 : 删除 一 个 空 目录 ,车 删除 成 功 则 返回 true; 否则 返回 false。 执 行 前 , 若 不 存在 指 
定 的 目录 , 则 报错 。 
说 明 : 如 果 目 录 不 为 空 ,必须 先 删除 目录 中 的 文件 才能 删除 目录 。 
【 例 8-2】 在 当前 目录 中 先 创建 path 目录 ,然后 删除 它 。 
<?php 
mkdir( "path"); 
if(rmdir("path")) echo "删除 成 功 !"; 
?> 
3. 获取 当前 工作 目录 
格式 : 
getcwd() 
功能 ; 取得 当前 的 工作 目录 , 即 正在 运行 的 文件 所 处 的 目录 。 若 成 功 则 返回 当前 的 工 
作 目 录 , 失 败 则 返回 false。 
【 例 8-3】 输出 当前 目录 。 
<?php 
echo getcwd( ); // 返 回 当前 工作 目录 
?> 
4. 打开 和 关闭 目录 句柄 
目录 句柄 可 以 看 作 目 录 路 径 的 一 个 别名 ,使 用 opendir() 函数 可 以 打开 一 个 目录 句柄 ， 
若 打开 成 功 则 返回 true, 失 败 则 返回 false。 
打开 目录 句柄 的 语法 格式 如 下 : 
目录 句柄 = opendir(" 目 录 路 径 ") 
为 了 节省 服务 器 资源 ,使 用 完 一 个 已 经 打开 的 目录 句柄 后 ,应 该 使 用 closedir() 函数 关 
闭 这 个 句柄 。 
关闭 目录 句柄 的 语法 格式 如 下 : 




















第 8 章 “PHP 常 用 功能 模块 (119 


closedir( 目 录 句 柄 ) 
【 例 8-4】 假设 path 为 当前 目录 的 上 一 级 目录 ,打开 path 目录 ,使 用 完 后 关闭 。 


<?php 
$dir="../path"; 
$dir_handle = opendir( $ dir); 
if( $ dir_handle) echo "打开 目录 句柄 成 功 !"; 
else echo "打开 失败 !"; 
closedir( $ dir_handle); 

?> 


5. 列 出 指定 路 径 中 的 文件 名 和 文件 夹 名 

(1) 使 用 readdir() 郴 数 

格式 : 

字符 串 变量 = readdir( 目 录 句 柄 ) ; 

说 明 : readdir() 的 参数 为 一 个 已 打开 的 目录 句柄 ,每 次 调用 会 返回 目录 中 的 一 个 文件 
名 或 文件 夹 名 。 该 函数 结合 while 语句 可 以 实现 对 目录 的 遍历 。 

【 例 8-5】 在 chap08 中 创建 一 个 EX8-5. php 网 页 ,使 用 readdir() 函数 遍历 MyPHP 站 
点 下 的 全 部 文件 和 文件 夹 。 


<?php 
$ dir ="../../MyPHP"; 
$ dir_handle = opendir( $ dir); // 打 开 目 录 句 柄 
$ file = readdir( $ dir_handle); // 读 取 目 录 中 的 一 个 文件 名 或 文件 夹 名 


while( $ file) 
{ 
echo $ file."<br/>"; 
$ file= readdir( $ dir_handle); 


} 

closedir( $ dir_handle); // 关 闭 目 录 句 柄 
?> 
(2) 使 用 scandir() 函数 
格式 : 


数组 名 = scandir(" 目 录 路 径 "); 

功能 : 将 指定 路 径 中 的 所 有 文件 名 和 文件 夹 名 依次 存 人 一 维 数组 中 。 

【 例 8-6】 在 chap08 中 创建 一 个 EX8-6. php 网 页 ,使 用 scandir() 函数 遍 历 MyPHP 站 
点 下 的 全 部 文件 和 文件 夹 。 


<?php 
$dir ="../../MyPHP"; 
$ file= scandir( $ dir); /VS file 为 数组 名 


foreach( $ fileas $x) 
{ 

echo $x."<br/>"; 
} 


?> 
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8.1.2 文件 的 打开 与 关闭 


目录 可 以 进行 打开 、 读 取 、 关 闭 、 删 除 等 操作 ,文件 的 操作 和 目录 操作 类 似 , 操 作文 件 的 
一 般 方法 有 打开 、 读 取 、 写 入 、 关 闭 等 。 

无 论 对 文件 进行 什么 操作 ,第 一 步 都 是 打开 文件 ,最 后 一 步 都 是 关闭 文件 。 

1. 打开 文件 

格式 : 

文件 句柄 = fopen(" 文 件 路 径 "，$ mode); 

说 明 : 文件 路 径 可 以 是 盘 符 ,协议 开头 的 绝对 路 径 ,也 可 以 是 相对 路 径 。 而 文件 句柄 可 
以 看 作文 件 路 径 的 一 个 别名 。 

其 中 ,参数 $mode 表示 文件 访问 模式 , 取 值 见 表 8-1。 
表 8-1 fopen() 函 数 的 文件 访问 模式 


























$ mode 说 明 

A 只 读 方 式 打开 文件 ,从 文件 头 开 始 读 。 如 果 文 件 不 存在 , 则 报错 

WB 读 写 方式 打开 文件 ,从 文件 头 开始 读 写 。 如 果 文 件 不 存在 , 则 报错 

Wt 1 写 方式 打开 文件 ,将 文件 指针 指向 文件 头 。 如 果 文件 不 存在 , 则 先 创建 它 
re 读 写 方式 打开 文件 ,将 文件 指针 指向 文件 头 。 如 果 文 件 不 存在 , 则 先 创建 它 
‘a 只 写 方式 打开 文件 ,将 文件 指针 指向 文件 尾 。 如 果 文 件 不 存在 , 则 先 创建 它 
入 读 写 方式 打开 文件 ,将 文件 指针 指向 文件 尾 。 如 果 文 件 不 存在 , 则 先 创建 它 
2. 关闭 文件 

文件 处 理 完毕 后 ,必须 使 用 fclose() 函 数 关闭 文件 ,语法 格式 如 下 : 
fclose( 文 件 句柄 ) 

【 例 8-7】 在 chap08 中 创建 一 个 EX8-7. php 网 页 ,以 读 写 方式 打开 EX8-6. php 文件 。 
<?php 


$ handle = fopen("EX8 — 6.php", "r+ "); 
if( $ handle) echo "打开 成 功 "; 
else echo "打开 文件 失败 "; 
fclose( $ handle); 
?> 


8.1.3 文件 的 写 人 


文件 在 写 人 之 前 需要 用 fopen() 函数 打开 文件 ,$ mode 可 以 取 "w"、"w 十 "、"a"、"a 十 "。 这 
时 ,如 果 文 件 不 存在 , 则 该 函数 先 创 建文 件 。 


下 面 是 两 个 创建 文件 的 例子 。 

<?php 
$ handlel = fopen("c:/wamp/www/p1.php"，"w"); // 在 C:/wamp/www 目录 下 创建 p1.php 
$ handle2 = fopen("p2. php”, "w"); // 在 当前 目录 下 创建 p2. php 


?> 
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(1) 使 用 fwrite() 函数 
文件 打开 后 ,向 文件 中 写 人 内容 可 以 使 用 fwrite() 函 数 ,语法 格式 如 下 : 


$n= fwrite( 文 件 句柄 ,字符 串 [, $ length] ) 


说 明 : 如 果 字 符 串 中 字 节 数 小 于 $ length, 则 写 人 整个 字符 串 后 停止 写 和 人。 如 果 写 人 操 
作成 功 ,fwrite() 函数 将 返回 写 人 的 字 节 数 ,出 现 错误 时 返回 false。 
【 例 8-8】 使 用 fwrite() 函数 向 p2. php 文件 中 写 和 “汕头 职业 技术 学 院 "。 
php 
$ handle = fopen("p2. php", "w+ "); 
$ num = fwrite( $ handle, "汕头 职业 技术 学 院 "); 
if( $ num) 
{ 
echo " 写 人 文件 成 功 < br/>"; 
echo " 写 人 的 字 节 数 为 ". $ num. "个 "; 
fclose( $ handle); 
} 
else echo "文件 写 人 失败 "; 


?> 

假设 网 页 编码 方式 为 UTF-8, 每 个 汉字 占 3 个 字 节 , 则 运行 结果 为 : 
写 入 文件 成 功 

写 人 的 字 节 数 为 24 个 

(2) 使 用 file_put_contents () 函数 


该 函数 的 功能 与 依次 调用 $ mode 为 "w" 的 fopen() fwrite() 及 fclose() 函 数 的 功能 一 
样 ,语法 格式 如 下 : 


$n=file_put_contents(" 文 件 路 径 ", 字 符 串 /数组 名 ) 


说 明 : 如 果 文 件 不 存在 , 则 先 创建 它 ; 如 果 文 件 已 存在 , 则 写 入 的 新 数据 将 覆盖 旧 数 
据 ; 写 人 成 功 后 函数 返回 写 和 的 字 节 数 , 否 则 返回 false。 
【 例 8-9】 使 用 file_put_contents() 函数 向 p2. php 文件 中 写 入 “汕头 职业 技术 学 院 ”。 
<?php 
$ num = file_put_contents("p2. php", "汕头 职业 技术 学 院 "); 
if( $ num) 
{ 
echo " 写 入 文件 成 功 < br/>"; 
echo " 写 人 的 字 节 数 为 ". $ num. "个"; 
} 
else echo "文件 写 人 失败 "; 


8.1.4 文件 的 读 取 


文件 在 读 取 之 前 需要 用 fopen() 函数 打开 文件 ,$mode 可 以 取 "r" 和 "r 十 "。 这 时 ,如 果 
文件 不 存在 则 自动 退出 。 
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1. 读 取 任意 长 度 
格式 ， 
字符 串 变量 = fread( 文 件 句柄 ，$ length) 


功能 : 从 打开 的 文件 中 读 取 $ length 个 字 节 到 字符 串 变量 中 。 若 编码 方式 为 GB2312， 
每 个 汉字 占 2 个 字 节 ; 若 编码 方式 为 UTF-8, 每 个 汉字 占 3 个 字 节 。 

$ length 的 最 大 数值 为 8192, 如 果 读 完 $length 个 字 节 数 之 前 遇 到 文件 结尾 标志 
(CEOF) , 则 返回 所 读 取 的 字符 ,并 停止 读 取 操作 。 

如 果 要 读 取 的 文件 中 包含 HTML 标记 ,这 时 需要 使 用 htmlspecialchars() 函 数 ,将 含有 
HTML 标记 的 字符 串 编 码 (如 志 编 为 &lt; ,二 编 为 &gt;) ,使 浏览 器 能 显示 HTML 标记 
本 身 。 

【 例 8-10】 新 建 EX8-10. php 网 页 ,将 EX8-9. php 的 源 代 码 显示 到 浏览 器 中 。 


<?php 
$ handle = fopen("EX8 — 9. php", "r"); // 打 开 文件 
$ content = ""; 
while(!feof( $ handle)) // 判 断 是 否 到 文件 末尾 
{ 
$ data = fread( $ handle, 8192); // 读 取 文 件 


$ content. = $ data; 
} 
echo htmlspecialchars( $ content); 
fclose( $ handle); // 关 闭 文 件 
?> 
说 明 : 上 述 代码 中 的 feof() 函 数 用 于 判断 是 否 到 达 文 件 末 尾 ,如 果 文 件 指针 到 达 文 件 
末尾 , 则 feof() 返 回 true; 否则 返回 false。feof() 函 数 的 语法 格式 如 下 : 


feof( 文 件 句 柄 ) 


2. 读 取 整个 文件 
(1) 使 用 file() 函数 
格式 : 


数组 名 = file(" 文 件 路 径 ") 


功能 : 将 整个 文件 内 容 读 取 到 一 维 数组 中 ,文件 中 的 一 行 读 取 到 数组 的 一 个 元 素 中 。 
用 于 将 一 个 网 页 的 源 代码 原样 显示 到 浏览 器 中 。 
【 例 8-11】 新 建 EX8-11. php 网 页 ,将 EX8-9. php 的 源 代码 原样 显示 到 浏览 器 中 。 


<?php 
$line = file("EX8— 9.php"); 
foreach( $ line as $ x) 
{ 
echo htmlspecialchars( $ x)."<br>"; 
} 


Ea 
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(2) 使 用 readfile() 函 数 

格式 : 

整 型 变量 = readfile(" 文 件 路 径 ") 

功能 : 将 整个 文件 内 容 读 取 到 浏览 器 中 ,并 返回 读 取 的 字 节 数 。 

注意 : readfile() 函 数 所 读 取 的 文件 一 般 为 文本 文件 (txt), 不 能 是 网 页 文件 。 
(3) 使 用 file_get_contents() 函 数 

格式 : 


字符 串 变量 = file_get_contents(" 文 件 路 径 ") 

功能 : 将 整个 文件 内 容 读 取 到 字符 串 变 量 中 。 功 能 与 依次 调用 fopen()、fread() 及 
fclose( ) 函 数 的 功能 一 样 。 

【 例 8-12】 新 建 EX8-12. php 网 页 ,将 EX8-9. php 的 源 代码 显示 到 浏览 器 中 。 


<?php 
$ content = file_get_contents("EX8— 9.php"); 
echo htmlspecialchars( $ content); 

?> 


3. 读 取 1 行 数据 

(1) 使 用 fgets() 函数 

格式 ， 

字符 串 变量 = fgets( 文 件 句柄 ) 

功能 : 从 打开 的 文件 中 读 取 1 行文 本 ,并 放 到 变量 中 。 用 于 将 一 个 网 页 的 源 代码 原样 
显示 到 浏览 器 中 。 

【 例 8-13】 新 建 EX8-13. php 网 页 ,将 EX8-9. php 的 源 代码 原样 显示 到 浏览 器 中 。 


<?php 
$ handle = fopen("EX8 — 9. php", "r"); // 打 开 文件 
$ content = ""; 


while(!feof( $ handle)) 
{ 


$ data= fgets( $ handle); // 读 取 文件 
echo htmlspecialchars( $ data). "< br >"; 
} 
fclose( $ handle); // 关 闭 文件 
?> 
(2) 使 用 fgetss() 函 数 
格式 : 


字符 串 变量 = fgetss( 文 件 句柄 ) 

功能 : 从 打开 的 文件 中 读 取 1 行文 本 ,去掉 其 中 的 HTML 标记 和 了 HP 脚本 后 ,再 放 到 
变量 中 。 

假设 当前 目录 下 的 1. txt 第 1 行内 容 为 <b 之 php</b>, 显 示 内 容 时 不 显示 php 的 加 


黑 效果 可 以 使 用 以 下 代码 。 


<?php 
$ handle = fopen("1. txt", "r"); 
$ one = fgetss( $ handle); 
echo $ one; 
fclose( $ handle); 
?> 


8.1.5 文件 的 上 传 与 下 载 


所 谓 文件 上 传 , 就 是 将 客户 端的 文件 传送 到 服务 器 的 指定 路 径 中 。 所 谓 文件 下 载 , 就 是 
将 服务 器 中 指定 路 径 的 文件 传送 到 客户 端 。 

1. 文件 上 传 

在 PHP 中 实现 文件 的 上 传 , 首 先 使 用 文件 域 控件 获取 客户 端的 文件 ,然后 使 用 move_ 
uploaded_file() 函数 将 客户 端的 文件 上 传 到 服务 器 。 

(1) 使 用 文件 域 控 件 获取 客户 端的 文件 

当 文件 域 控件 获取 客户 端的 文件 后 ,需要 使 用 预定 义 变量 $_FILES 提取 文件 的 详细 
信息 。$_FILES 是 一 个 二 维 数组 , 它 包 含 如 下 元 素 。 
$_FILES[ ' 文 件 域名 ]['name ']: 客户 端 上 传 的 文件 名 。 
$_FILES[ ' 文 件 域名 “]['type: 上 传 文件 的 类 型 ,需要 浏览 器 提供 该 信息 的 支持 。 
常用 的 值 有 : text/plain 表示 普通 文本 文件 ; image/gif 表示 GIF 图 片 ; image/jpeg 
表示 JPEG 图 片 ; application/msword 表示 Word 文件 ; application/vnd. ms-excel 
表示 Excel 文件 ; text/html 表示 HTML 格式 的 文件 ; application/pdf 表示 PDF 格 
式 文件 ; audio/mpeg 表示 MP3 格式 的 音频 文件 ; application/ x-zip-compressed 表 
示 ZIP 格式 的 压缩 文件 ; application/octet-stream 表示 二 进 制 流 文件 ,如 EXE 文 
件 .RAR 文件 .视频 文件 等 。 
$_FILES[ ' 文 件 域名 ]['tmp_name']: 文件 上 传 到 服务 器 后 生成 的 临时 文件 路 径 ， 
即 C:\wamp\tmp\phpXX. tmp( 其 中 XX 是 可 变 的 ) 。 
$_FILES[ ' 文 件 域名 ']['size ']: 上 传 文件 的 大 小 ,单位 为 字 节 。 
$_FILES[ ' 文 件 域名 '][ 'error ']: 错误 信息 代码 。 值 为 0 表示 没有 错误 发 生 , 文 件 
上 传 成 功 ; 值 为 1 表示 上 传 的 文件 超过 了 php. ini 文件 中 upload_max_filesize 选项 
限制 的 值 ( 默 认为 2M):; 值 为 2 表示 上 传 文件 的 大 小 超过 了 HTML 表单 中 规定 的 
最 大 值 ; 值 为 3 表示 文件 只 有 部 分 被 上 传 ; 值 为 4 表示 没有 文件 被 上 传 ; 值 为 5 表 
示 上 传 文件 大 小 为 0。 

(2) 使 用 move_uploaded_file( ) 函 数 将 客户 端的 文件 上 传 到 服务 器 

格式 : 

move_uploaded_file(" 文 件 上 传 后 的 临时 文件 路 径 "，" 目 标 文件 路 径 ") 

功能 : 将 文件 上 传 到 服务 器 后 ,首先 以 临时 文件 名 存储 ,再 将 临时 文件 移动 到 目标 位 置 
并 更 名 。 如 果 目 标 文件 已 经 存在 , 则 旧 文 件 会 被 新 文件 覆盖 。 如果 上 传 文件 不 合法 或 文件 
无 法 移动 , 则 函数 不 会 进行 任何 操作 并 返回 false。 
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【 例 8-14】 在 chap08 目录 下 新 建 EX8-14. php 网 页 ,将 客户 端 上 传 的 文件 存放 到 
chap08\upload 目录 下 ,并 输出 上 传 文件 的 名 称 、 类 型 .大 小 。 
代码 如 下 : 
<?php 
if(isset( $_POST[ "up7])) 
{ 
$ filename = $ _FILES[ ‘myFile’][ 'name']; // 客 户 端 上 传 的 文件 名 
$ filename = iconv("UTF -8","GB2312", $ filename); // 对 中 文 文件 名 进行 编码 
$ tmp_filename = $ _FILES[ ‘myFile'][ ‘tmp_name']; 
// 文 件 上 传 到 服务 器 后 生成 的 临时 文件 路 径 
if(move_uploaded _ file( $ tmp_filename, "upload/ $ filename" )) 
// 实 现 上 传 ,将 临时 文件 移动 到 目标 位 置 并 更 名 
{ 
echo "文件 名 称 : ". $ _FILES [ 'myFile'][ 'name']."<br>"; 
echo "文件 类 型 : ". $ _FILES [ 'myFile']['type']."<br>"; 
echo "文件 大 小 : ". ( $ _FILES[ 'myFile'][ 'size']/1024)."KB"; 


} 
?> 
注意 ; 实现 文件 上 传 必须 满足 3 个 条 件 : 表单 必须 使 用 post 方法 提交 ; 加 一 form> 
标记 必须 加 入 enctype 二 "multipart/form-data"; @ 表 单 中 要 含有 一 个 文件 域 控件 。 
2. 文件 下 载 
在 PHP 中 实现 文件 的 下 载 ,有 下 列 两 种 方法 。 
(1) 使 用 文件 超 链接 
文件 超 链接 的 HTML 标记 为 二 a href 二 "文件 名 "二 文本 或 图 像 二 /a 二 , 当 超 链接 的 目 
标 文件 为 文本 文件 (. txt) ,图像 文 件 (. jpg、 gif) 和 网 页 文件 (. asp、. aspx、. jsp、. php、. htm) 
以 外 的 文件 时 ,就 成 为 “文件 下 载 "。 优 点 是 可 下 载 任意 类 型 的 文件 ,缺点 是 直接 暴露 目标 文 
件 所 在 路 径 , 可 能 会 有 安全 隐患 。 
(2) 使 用 header() 和 readfile() 函数 
header() 函数 的 作用 是 向 浏览 器 发 送 正确 的 HTTP 报头 ,报头 指定 了 网 页 内 容 的 类 
型 .页面 的 属性 等 信息 。header() 函数 的 功能 很 多 .这 里 只 列 出 以 下 几 点 。 
。 页 面 跳 转 。 如 果 header() 函数 的 参数 为 Location: xxx, 页面 就 会 自动 跳 转 到 xxx 
指向 的 URL 地址。 例如 ,header("Location: http://www. baidu. com")。 
。 指定 网 页 内 容 。 例 如 ,同样 的 一 个 XML 格式 的 文件 ,如 果 header() 函 数 的 参数 指定 
为 Content-type: application/xml, 浏 览 器 会 将 其 按照 XML 文件 格式 来 解析 。 如 果 
是 Content-type: text/xml, 浏 览 器 就 会 将 其 看 作文 本 解析 。 
。 文件 下 载 。header() 函数 结合 readfile() 函 数 可 以 下 载 将 要 浏览 的 文件 。 优 点 是 不 
会 暴露 目标 文件 所 在 的 路 径 ,缺点 是 只 能 下 载 文本 文件 (. txt)、 图 像 文件 (. jpg、 
.gif) 和 网 页 文件 (. asp、. aspx、. jsp、. php、. htm)。 
【 例 8-15】 在 chap08 目录 下 新 建 EX8-15. php 网 页 ,将 chap08\download 目录 下 
的 1. txt 下载 到 客户 端 。 


代码 如 下 : 


<?php 
$ name = "download/1. txt"; 
header( "Content - Disposition:attachment ;filename = 1. txt"); // 设 置 下 载 文件 的 文件 名 
readfile( $ name); // 读 取 文 件 

?> 


8.1.6 其 他 常用 文件 函数 

1. 计算 文件 大 小 

格式 : 

filesize(" 文 件 路 径 ") 

功能 : 计算 文件 的 大 小 ,以 字 节 为 单位 。 
例如 : 


<?php echo filesize( "download/1. txt"); ?> 


2. 判断 文件 是 否 存在 
格式 : 
file_exists(" 文 件 路 径 / 目 录 路 径 ") 
功能 : 检查 文件 或 目录 是 否 存 在 ,如 果 存 在 则 返回 true; 否则 返回 false。 
例如 : 
<?php 
if(file_exists("download/1. txt")) echo "文件 存在 "; 
else echo "该 文件 不 存在 "; 
?> 
PHP 还 提供 一 些 函 数 , 用 于 判断 给 定 路 径 是 目录 路 径 还 是 文件 路 径 。 例 如 ,is_dir(" 路 
径 ") 用 于 判断 给 定 路 径 是 否 是 目录 .is_file(" 路 径 ") 用 于 判断 给 定 路 径 是 否 是 文件 。 
3. 删除 文件 
格式 : 
unlink(" 文 件 路 径 ") 
功能 : 删除 指定 的 文件 ,如 果 删 除 成 功 则 返回 true; 否则 返回 false。 
【 例 8-16】 写 一 个 函数 ,用 于 删除 任 一 个 非 空 目 录 。 





<?php 
function del_dir( $ dir) // 删 除非 空 目录 
{ 
$ handle = opendir( $ dir); // 打 开 目 录 句 柄 
$ file= readdir( $ handle); // 读 取 目 录 中 的 一 个 文件 名 或 文件 夹 名 


while( $ file) 
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if ($file!= '. '&& $file!= '..') 
{ 
$dirname= $dir.'/'. $file; 
if (is_file( $ dirname)) unlink( $ dirname); // 若 是 文件 ,就 直接 删除 


else del_dir( $ dirname); 


} 
$ file= readdir( $ handle); // 读 取 目 录 中 下 一 个 文件 名 或 文件 夹 名 
} 
closedir( $ handle); // 关 闭 目录 句柄 
return(rmdir( $ dir)); // 删 除 空 目录 , 若 删除 成 功 则 返回 true 
} 
?> 
4. 复制 文件 
格式 : 


copy(" 源 文件 路 径 ", "目的 文件 路 径 " ) 
功能 : 将 一 个 文件 从 原 位 置 复制 到 新 位 置 。 目 的 文件 可 以 与 源 文件 同名 ,也 可 以 
重新 命名 。 如 果 复 制 成 功 则 返回 true; 否则 返回 false。 如 果 目 的 文件 已 经 存在 , 则 将 
被 覆盖 。 
【 例 8-17】 在 chap08 目录 下 新 建 EX8-17. php 网 页 ,将 chap08/download/1. txt 复制 
到 chap08 目录 下 ,文件 名 不 变 。 
<?php 
$ source = "download/1. txt"; 
$ target = "1. txt"; 


if(copy( $ source, $ target)) echo "复制 成 功 !"; 
| 


5. 移动 文件 

格式 ， 

rename(" 源 文件 路 径 ", "目的 文件 路 径 ") 

功能 : 将 一 个 文件 从 原 位 置 移动 到 新 位 置 ,可 以 保持 原名 ,也 可 以 改名 。 
例如 : 


?php 

$ source = "download/1. txt"; 

$ target = "1. txt"; 

if(rename ( $ source, $ target) ) echo "移动 成 功 !"; 
Pe 


6. 文件 指针 操作 
rewind( 文 件 句 柄 ): 重 置 文件 指针 的 位 置 ,使 指针 返回 到 文件 头 。 


ftell( 文 件 句柄 ): 报告 文件 指针 的 位 置 。 
fseek( 文 件 句柄 ,n) : 将 文件 指针 移动 到 第 n 个 字 节 。 





【 例 8-18】 文件 指针 操作 示例 。 


<?php 
$ file = "C:/wamp/www/index. php"; 
$ handle = fopen( $ file, "r"); 





echo "当前 指针 为 : ".ftell( $ handle). "< br/>"; 

fseek( $ handle, 100); 

echo "当前 指针 为 : ". ftell( $ handle). "<br/>"; 

rewind( $ handle); 

echo "当前 指针 为 : ".ftell( $ handle). "< br/>"; 
2 


8.1.7 实例 一 一 投票 统计 


【 例 8-19】 使 用 之 前 学 过 的 文件 操作 方法 ,编写 一 个 计算 投票 数量 的 程序 。 


新 建 一 个 EX8-19. php 网 页 ,输入 以 下 代码 。 


<! DOCTYPE html > 
<! -- HTML5 表单 -一 > 
< style type = "text/css"> 
div{ 
font - size:18px; 
color: #0000FF; 


} 
1i{ 
font — size:24px; 
color: # FF0000; 
} 
</style> 
< form enctype = "multipart/form— data" action = "" method = "post"> 
<table> 
<tr> 


<td bgcolor =" 井 CCCCCC"> 


<div> 当 前 最 流行 的 Web 开发 语言 : </div> 


</td> 
</tr> 
<tr> 


<td>< input type = "radio" name = "vote"” value = "PHP"> PHP </td> 


</tr> 
<tr> 


<td>< input type = "radio" name = "vote"” value = "RSP"> ASP </td> 


</tr> 
<tr> 


<td>< input type = "radio" name = "vote" value = "JSP"> JSP </td> 


</tr> 
<tr> 


<td>< input type = "submit" name = "sub" value= "请 投票 "></td> 


</tr> 
</table> 
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</form> 
<?php 
$ votefile = "EX8 — 19 — vote. txt"; // 用 于 计数 的 文本 文件 $ votefile 
if(!file exists( $ votefile)) // 判 断 文件 是 否 存在 
{ 
$ handle = fopen( $ votefile, "w+"); // 不 存在 则 创建 该 文件 
fwrite( $ handle, "0|0|0"); // 将 文件 内 容 初始 化 


fclose( $ handle); 
} 
if(isset( $ _POST[ 'sub'])) 
{ 
if(isset( $ _POST[ "vote'])) // 判 断 用 户 是 否 投票 
{ 
$ vote = $ _POST[ 'vote']; // 接 收 投票 值 
$ handle = fopen( $ votefile, "r+ "); 
$ votestr = fread( $ handle, filesize( $ votefile)); 
// 读 取 文件 内 容 到 字符 串 $ votestr 
fclose( $ handle); 
$ votearray = explode("|"，$ votestr); // 将 $ votestr 根据 "| "分 割 
echo "< h3 > 投票 完毕 !</h3a >"; 
if( $ vote == PHP') 
$ votearray[ 0]++; // 如 果 选 择 PHP, 则 数组 第 1 个 值 加 1 
echo "目前 PHP 的 票数 为 : <1i>". $ votearray[0]."</1i><br/>"; 
if( $ vote == ‘ASP') 
$ votearray[ 1]++; // 如 果 选 择 RSP, 则 数组 第 2 个 值 加 1 
echo "目前 ASP 的 票数 为 : <1i>". $ votearray[1]."</1i><br/>"; 
if( $ vote== 'JSP') 


$ votearray[ 2]++; // 如 果 选 择 JSP, 则 数组 第 3 个 值 加 1 
echo "目前 JSP 的 票数 为 : <1i>". $ votearray[2]."</1i><br/>"; 
// 计 算 总 票数 


$ sum = $ votearray[0] + $ votearray[1] + $ votearray[2]; 
echo "总 票数 为 : <1i>". $ sum. "</1i><br/>"; 
$ votestr2 = implode("|", $ votearray); 
// 将 投票 后 的 新 数组 用 "| "连接 成 字符 串 $ votestr2 
$ handle = fopen( $ votefile "w+"); 
fwrite( $ handle, $ votestr2); // 将 新 字符 串 写 入 文件 $ votefile 
fclose( $ handle); 
} 
else 
{ 
echo "< script >alert( ' 未 选择 投票 选项 ! ')</script >"; 


ea 


保存 后 运行 该 文件 ,选择 单 选 按钮 进行 投票 ,运行 结果 如 图 8-2 所 示 。 














股票 完毕 ! 
目前 PHP 的 票数 为 : 
已 


目前 ASP 的 票数 为 : 
0 





目前 JSP 的 票数 为 : 





8-2 ”投票 统计 结果 


8.2 日 期 和 时 间 


在 操作 数据 库 时 ,经 常 需要 处 理 一 些 日 期 和 时 间 类 型 数据 。 
8.2.1 UNIX 时 间 截 


在 当前 大 多 数 的 UNIX 系统 中 ,表示 当前 日 期 和 时 间 的 方法 是 : 采用 格林 尼 治 时 区 ,从 
1970 年 1 月 1 日 零点 起 到 当前 时 刻 的 秒 数 。 从 1970 年 1 月 1 日 零 时 起 到 某 一 具体 时 间 的 
秒 数 , 称 为 该 时 间 的 UNIX 时 间 戳 ,简称 时 间 戳 , 它 是 一 个 长 整数 。Windows 系统 也 可 以 使 
用 时 间 戳 ,但 如 果 时 间 是 在 1970 年 以 前 或 2038 年 以 后 ,处 理 时 可 能 会 出 现 问题 。 

PHP 在 处 理 有 些 数据 ,特别 是 对 数据 库 中 时 间 类 型 的 数据 进行 格式 化 时 ,经 常 需要 先 
将 时 间 类 型 的 数据 转化 为 UNIX 时 间 戳 ,再 进行 处 理 。 另 外 ,不 同 的 数据 库 系 统 对 时 间 类 
型 的 数据 不 能 兼容 转换 ,这 时 就 需要 将 时 间 转 化 为 UNIX 时 间 戳 ,再 对 时 间 惟 进行 操作 ,这 
样 就 实现 了 不 同 数据 库 系 统 的 跨 平台 性 。 


8.2.2 时 间 转 化 为 时 间 截 
格式 1， 


strtotime( 'Y-m-d H:i:s') 

格式 2: 

mktime(H, i, s,m, d,Y) 

功能 : 将 日 期 和 时 间 转 化 为 时 间 戳 。 
例如 : 


<?php 
echo strtotime( '2016—11— 18 21:44:00'). '<br>'; // 输 出 : 1479476640 
echo mktime(21, 44, 0, 11,18, 2016); // 输 出 : 1479476640 
?> 


特别 地 ,下 面 3 条 语句 都 可 以 获取 系统 当前 的 时 间 戳 。 
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<?php 


echo strtotime(date( 'Y—-m-— dH:i:s')). ‘<br>'; 
echo mktime( ); 
echo time(); 


> 


8.2.3 获取 日 期 和 时 间 
1. date() 函 数 


格式 : 


date( 格 式 串 [, 时 间 惟 ]) 
功能 : 将 时 间 戳 按照 给 定 的 格式 转化 为 具体 的 日 期 和 时 间 , 若 省 略 时 间 改 , 则 默认 为 


time()。 其 中 ,格式 串 是 由 普通 字符 、 特 殊 字 符 组 成 的 字符 串 。 


例如 : 


<?php 


echo date( 'Y—-m- dH:i:s 1',time()). "<br>"; 
echo date( 'Y—-m- dH:i:s 1')."<br>"; 
echo date( 'Y-m-d', strtotime( '2016- 11- 18 21:44:00'))."<br>"; // 固 定时 间 的 日 期 部 分 


// 获 取 系统 当前 的 日 期 ,时间 、 星 期 几 
// 获 取 系统 当前 的 日 期 时间、 星期 几 





















































echo date( 'Y—m-—d', strtotime( '2016 — 11 — 18 21:44:00°)); // 固 定时 间 的 时 间 部 分 
-> 
date 函数 支持 的 特殊 字符 如 表 8-2 所 示 。 
表 8-2 date 函数 支持 的 特殊 字符 
字 符 说 明 返回 值 例子 
天 
d 月 份 中 的 第 几 天 ,有 前 导 零 的 2 位 数字 01~31 
D 星期 中 的 第 几 天 ,用 3 个 字母 表示 Mon~Sun 
j 月 份 中 的 第 几 天 ,没有 前 导 零 1~31 
1(L 的 小 写 ) | 星期 几 .完整 的 文本 格式 Sunday~ Saturday 
N ISO 8601 格式 数字 表示 的 星期 中 的 第 几 天 1( 星 期 一 ) 一 7( 星 期 天 ) 
stvndvrd 或 者 th。 可 以 和 j 
S | 每 月 天 数 后 面 的 英文 后 组 ,用 2 个 字符 表示 ee 
Ww 星期 中 的 第 几 天 ,数字 表示 0( 星 期 天 ) 一 6( 星 期 六 ) 
z 年 份 中 的 第 几 天 0~365 
星 期 
Ww ISO 8601 格式 年 份 中 的 第 几 周 ,每 周 从 星期 一 开始 42( 当 年 的 第 42 周 ) 
月 

F 月 份 .完整 的 文本 格式 ,例如 January 或 者 March January ~ December 
m 数字 表示 的 月 份 .有 前 导 零 01 一 12 
M 3 个 字母 缩写 表示 的 月 份 Jan 一 Dec 
n 数字 表示 的 月 份 ,没有 前 导 零 l= 
和 给 定 月 份 所 应 有 的 天 数 28 一 31 
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续 表 
字 符 说 明 返回 值 例子 
年 
L 是 否 为 头 年 如 果 是 头 年 则 为 1; 否则 为 0 
ISO 8601 格式 年 份 数字 。 这 和 YY 的 值 相同 ,只 是 如 果 
° 1SO 的 星期 数 (W) 属 于 前 一 年 或 下 一 年 , 则 用 那 一 年 。 | 例如 '1999 或 2003 
Y 4 位 数字 完整 表示 的 年 份 例如 ,1999 或 2003 
六 2 位 数字 表示 的 年 份 例如 ,99 或 03 
时 间 
a 小 写 的 上 午 和 下 午 值 am 或 pm 
A 大 写 的 上 午 和 下 午 值 AM 或 PM 
B Swatch Internet 标准 时 000~999 
8 小 时 ,12 小 时 格式 ,没有 前 导 零 1 一 12 
G 小 时 ,24 小 时 格式 ,没有 前 导 零 0 一 23 
h 小 时 ,12 小 时 格式 ,有 前 导 零 01~12 
H 小 时 ,24 小 时 格式 .有 前 导 零 00 一 23 
i 分 钟 数 , 有 前 导 零 00 一 59 
s 秒 数 ,有 前 导 零 00~59 
时 区 

例如 ,UTC( 世 界 统一 时 区 )、 
e 时 区 标识 GMT( 格 林 尼 治 时 区 )、PRC 

(北京 时 区 ) 

和 夏 今 办 和 

1 是 否 为 夏令 时 oo 否则 
O 与 格林 尼 治 时 间 相 差 的 小 时 数 例如 ,十 0200 
人 例如 ,十 08:00 








注意 : 在 PHP 中 ,使 用 date('Y-m-d Hi:i:s') 获 取 的 时 间 与 系统 时 间 相 差 8 小 时 。 若 
希望 两 者 相同 ,有 如 下 两 种 解决 办 法 。 

(1) 打开 php.ini 文件 ,将 其 中 的 date. timezone 一 UTC 改 成 date. timezone 一 PRC， 
并 重新 启动 Apahce 服务 器 。 

(2) 在 PHP 脚本 中 ,将 默认 时 区 设置 为 北京 时 区 , 即 : 


date_default_timezone_set( 'PRC'); 
2. getdate() 函 数 

格式 : 

数组 名 = getdate([, 时 间 惟 ]) 


功能 : 将 时 间 戳 转化 为 日 期 和 时 间 人 信息, 并存 人 数组 中 。 若 省 略 时间 截 , 则 默认 为 time()。 
注意 : getdate() 函 数 生成 的 数组 的 键 名 和 值 如 表 8-3 所 示 。 
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<?php 
$arrayl = getdate( ); 
S$ array2 = getdatel( strtotime( 2016 — 09 — 26")); 
print_r( $ arrayl); 
print_r( $ array2); 









































?> 

表 8-3 getdate( ) 函 数 生成 的 数组 的 键 名 和 值 
键 名 说 明 值 的 例子 
seconds 秒 的 数字 表示 0~59 
minutes 分 钟 的 数字 表示 0~59 
hours 小 时 的 数字 表示 0~23 
mday 月 份 中 第 几 天 的 数字 表示 1~31 
wday 星期 中 第 几 天 的 数字 表示 0( 表 示 星 期 天 ) 一 6( 表 示 星 期 六 ) 
mon 月 份 的 数字 表示 1 一 12 
year 4 位 数字 表示 的 完整 年 份 例如 ,1999 或 2003 
yday 一 年 中 第 几 天 的 数字 表示 0 一 365 
weekday 星期 几 的 完整 文本 表示 Sunday 一 Saturday 
month 月 份 的 完整 文本 表示 January 一 December 


8.2.4 ”其 他 日 斯 和 时 间 函 数 


1. 检查 日 期 
checkdate() 函 数 用 于 检查 一 个 日 期 数据 是 否 有 效 ,语法 格式 如 下 : 


bool checkdate( int $ month, int $ day, int $ year) 


注意 ; $ year 的 值 是 1 一 32767. $ month 的 值 1 一 12, $day 的 值 在 给 定 的 $month 值 
所 具有 的 天 数 范围 内 ,其 中 半年 的 情况 也 考虑 在 内 。 
例如 : 
<?php 
var_dump(checkdate(12, 31, 2000)); 


var_dump(checkdate(2, 29, 2001)); 
?> 


2. 设置 时 区 

PHP 提供 了 可 以 修改 时 区 的 函数 date_default_timezone_set() ,语法 格式 如 下 : 

bool date_default_timezone_set (string $ timezone_identifier) 

系统 默认 的 是 格林 尼 治 标准 时 间 , 所 以 显示 当前 时 间 时 可 能 与 本 地 时 间 会 有 差别 。 参 


数 $ timezone_identifier 为 要 指定 的 时 区 ,中 国内 地 可 用 的 值 是 Asia/Chongqing, Asia/ 
Shanghai, Asia/Urumqi( 依 次 为 重庆 、 上 海 、 乌 鲁 木 齐 )。 北 京 时 间 可 以 使 用 PRC。 





<?php 
date_default_timezone_set( 'PRC'); 
echo date("h:i:s",time()); 

?> 


8.2.5 ”实例 一 一 生成 日 历 


【 例 8-20】 输出 某 个 月 的 日 历 ,要 求 年 份 和 月 份 可 以 进行 选择 。 
新 建 一 个 EX8-20. php 网 页 ,输入 以 下 代码 。 


<?php 
$ year = @ $ _GET[ 'year ']; 
$ month= @ $ _GET[ ‘month']; 
if(empty( $ year)) 
$ year = date("Y"); 
if(empty( $ month) ) 
$ month= date( "n"); 
$ day= date("j"); 
wlar=array(" HH" —" = 
$ wd = date("w", mktime(0,0,0, $ month, 1, $ year)); 


$ y_lnkl = $ year <= 1970? $ year = 1970: $ year — 1; 
$ y_lnk2= $ year >= 2037? $ year = 2037: $ year + 1; 


$m lnkl= $month<= 1?$ month= 1: $month— 1; 
$ mlnk2= $month>= 12? $ month= 12: $ month+1; 
echo "< table cellpadding = 6 cellspacing = 0 width = 200 bgcolor = # eeeeee ><tr align = 
center bgcolor = #cccccc>"; 
echo "<td colspan =4><a href = 'SL8_2_8.php?year = $y_lnklgmonth= $ month'> 
<</a>". $ year. "年 <a href = 'SL8_2_8.php?year = $ y_lnk2g&month= $ month’>></a> 
</td>"; 
echo "<td colspan = 3 ><a href = 'SL8_2_8.php?year = $ year&month= $m_lnkl’> 
<</a>". $month." 月 <a href = 'SL8_2_8. php?year = $ yearg&month= $m_lnk2'>></a> 
</td></tr >"; 
echo "<tr align = center >"; 
for( $i=0;$i<7; $it+) 
{ 
echo "<td>$ wd_ar[ $ i]</td> "; 
} 
echo "tr 
$ tnum= $ wd+date("t",mktime(0,0,0, $ month,1, $ year)); 
for( $i=0;$i<$tnum; $i++) 
{ 
$date= $i+1— $wd; 
if( $i%7==0) echo "<tralign= center >"; 
echo "< td>"; 
if($i>= $wd) 
{ 
if( $date== $ dayg&& $ month== date("n")) 
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echo "<b>". $ day. "</b>"; 
else 
echo $ date; 
} 
echo "</td> "; 
if( $i%7==6) 
echo "</tr>"; 
} 
echo "</table >"; 
Ee 


运行 结果 如 图 8-3 所 示 。 
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图 8-3 显示 日 历 
8.3 图 形 处 理 


PHP 不 仅 可 以 进行 文本 处 理 , 还 能 进行 图 像 处 理 。 在 生成 校 验 码 ,绘制 动态 图 表 、 给 图 
片 添加 水 印 等 方面 都 需要 用 到 图 像 处 理 技术 。 虽 然 PHP 中 有 一 些 简单 的 图 形 .图 像 处 理 
函数 可 以 直接 使 用 ,但 是 绝 大 多 数 要 处 理 的 图 像 都 要 通过 GD 库 来 处 理 。 


8.3.1 安装 PHP 图 像 库 


在 PHP 中 有 的 图 形 函数 可 以 直接 使 用 ,但 大 多 数 函 数 需 要 安装 GD 2 函数 库 后 才能 使 
用 。 有 关 GD 2 的 详细 信息 ,读者 可 以 自行 参考 相关 资料 。 在 Windows 平台 下 ,安装 GD 2 
库 很 简单 ,PHP 5 中 自 带 了 GD 2 库 扩 展 (就 是 PHP 的 ext 目录 中 的 php_gd2. dll 文件) ,一 
般 在 安装 WampServer 时 已 经 安装 了 所 有 的 扩展 库 , 包 括 GD 库 。 


8.3.2 创建 图 形 

建 图 形 步 又 如 下 。 

1. 创建 背景 图 形 

创建 背景 可 以 使 用 imagecreate() 和 imagecreatetruecolor() 函 数 , 这 两 个 函数 都 可 以 创 


建 一 个 空白 的 图 形 , 并 返回 一 个 图 像 标 识 符 ( 也 可 以 称 为 句柄 ) , 供 其 他 函数 使 用 。 
语法 格式 如 下 : 


[eg 
到 
和 





resource imagecreate(int $ x_ size, int $y_size) 


resource imagecreatetruecolor(int $ x_size, int $y_size) 


注意 ; $ x_size 是 背景 的 宽度 ,$y_size 是 背景 的 高 度 ,imagecreate() 函 数 用 于 建立 一 
个 基于 调 色 板 的 图 形 , 创 建 后 可 改变 背景 颜色 。imagecreatetruecolor() 函 数 用 于 创建 一 个 
真 彩色 图 形 , 背 景 颜色 默认 为 黑色 。 如 果 图 形 创建 成 功 ,函数 将 返回 一 个 句柄 ; 如 果 失 败 ， 
并 不 会 像 其 他 函数 一 样 返回 false, 这 时 可 以 使 用 die() 函 数 来 捕获 错误 信息 。 例 如 : 


$ image = imagecreate(200,200) or die(" 创 建 图 形 失败 !"); 


2. 使 用 已 有 图 片 创 建新 图 形 
除了 可 以 创建 空白 的 背景 图 形 外 ,还 可 以 将 已 有 的 图 片 作 为 背景 图 形 来 创建 新 的 图 形 。 
如 imagecreatefromgif() 函数 可 以 根据 已 有 的 GIF 图 片 创 建新 图 形 ,imagecreatefromjpeg() 
函数 可 以 根据 已 有 的 JPEG 图 片 创建 新 图 形 , $imagecreatefrompng() 函数 可 以 根据 已 有 的 
PNG 图 片 创 建新 图 形 。 已 有 的 图 片 也 可 以 是 远程 的 图 片 文件 。 例 如 : 
<?php 
$ imfile = "images/piaoluo. gif"; 
$ image = imagecreatefromgif( $ imfile); 
header( "Content - type: image/gif"); 
imagegif( $ image); 
?> 


3. 选择 颜色 

在 处 理 图 形 的 操作 中 ,经 常 需要 为 图 形 的 某 些 部 分 分 配 颜色 ,这 时 颜色 值 的 选择 就 需要 
使 用 imagecolorallocate() 函数 来 完成 。 语 法 格式 如 下 : 

int imagecolorallocate ( resource $ image, int $ red, int $ green, int $ blue ) 

注意 : $ red、$ green 和 $blue 分 别 是 所 需 颜 色 的 红 、 绿 、 蓝 成 分 。 这 些 参数 是 0 一 255 
的 整数 或 者 十 六 进 制 数 0x00~0xFF。 函 数 必 须 调 用 imagecolorallocate() 以 创建 每 一 种 用 
在 $image 所 代表 的 图 形 中 的 颜色 。 例 如 : 


<?php 
$ im = imagecreate(200,200); // 新 建 背景 图 形 
$ background = imagecolorallocate( $ im,255,0,0); // 背 景 设 为 红色 
// 设 定 一 些 颜 色 
$ white = imagecolorallocate( $ im, 255, 255,255); // 白 色 
$ black = imagecolorallocate( $ im, 0, 0,0); // 黑 色 

?> 


说 明 : 第 一 次 调用 imagecolorallocate() 函数 时 会 给 基于 调 色 板 的 图 形 填 充 背 景色 。 例 
中 的 $ white、$ black 颜色 定义 后 就 可 以 在 其 他 函数 中 使 用 该 颜色 对 图 形 中 的 某 一 部 分 进 
行 着 色 了 。 

4. 输出 图 形 

如 果 需 要 将 已 经 绘制 的 图 形 输 出 到 浏览 器 或 文件 中 ,可 以 使 用 相应 的 函数 来 完成 。 使 
用 imagegif() 可 以 将 图 形 以 GIF 格式 输出 到 浏览 器 或 文件 中 ,imagejpeg() 将 图 形 以 JPEG 
格式 输出 ,imagepng() 函 数 将 图 形 以 PNG 格式 输出 。 语 法 格式 如 下 : 
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bool imagepng(resource $ image [, string $ filename ]) 

bool imagegif(resource $ image [, string $ filename ]) 

bool imagejpeg(resource $ image [, string $ filename [, int $ quality ]]) 

不 管 输出 什么 格式 的 图 片 ,都 要 使 用 header() 函数 向 浏览 器 发 送 相应 的 头 信息 ,如 果 
要 输出 GIF 格式 的 图 片 应 使 用 header("Content-type: image/gif") ;输出 JPEG 格式 的 图 
片 应 使 用 header("Content-type: image/jpeg"); 输 出 PNG 格式 使 用 header("Content- 
type: image/png")。 例 如 : 

















<?php 
$ image = imagecreate(400, 400); // 创 建 背景 图 形 
$ back_color = imagecolorallocate( $ image, 255, 0, 0); // 设 置 背 景 颜色 为 红色 
header("Content - type: image/gif"); // 发 送 头 信息 ,使 脚本 输出 GIF 格式 文件 
imagegif( $ image " images/back. gif"); // 将 图 形 保存 为 back. gif 文件 
imagegif( $ image); // 在 浏览 器 中 输出 图 形 

?> 

5. 清除 资源 


为 了 节省 资源 ,图 片 创建 后 返回 的 句柄 如 果 不 再 使 用 ,就 要 用 imagedestroy() 函 数 来 释 
放 与 之 相关 的 内 存 。 语 法 格式 如 下 : 


imagedestroy( $ image); 
其 中 , $ image 是 已 经 创建 的 句柄 。 

8.3.3 绘制 图 形 

在 掌握 了 一 些 最 基本 的 图 形 操作 后 ,就 可 以 在 已 经 创建 的 画布 (背景 图 形 ) 上 绘制 具体 
的 图 形 了 。PHP 中 可 以 绘制 的 图 形 有 几何 图 形 .文本 文字 ,颜色 块 等 。 

1. 绘制 几何 图 形 

(1) 画 一 个 点 

使 用 imagesetpixel() 函数 可 以 在 已 经 创建 的 背景 图 形 上 画 一 个 单一 像素 , 即 一 个 点 。 
语法 格式 如 下 ， 


bool imagesetpixel(resource $ image, int $ x, int $y, int $color ) 


说 明 : imagesetpixel() 函数 在 已 经 创建 的 背景 图 形 $image 上 用 $color 颜色 在 ($x， 
$y) 坐 标 上 画 一 个 点 。 
【 例 8-21】 在 (100,100) 坐 标 上 画 一 个 蓝 色 的 点 。 
<?php 
$ image = imagecreate(200,200) // 创 建 背景 图 形 


$ background = imagecolorallocate( $ image,255,255, 255); // 背 景色 设置 为 白色 
$ blue = imagecolorallocate( $ image, 0,0,255); // 定 义 蓝 色 


imagesetpixel( $ image, 100, 100, $ blue); // 画 一 个 蓝 色 的 点 
header( "Content — type: image/gif"); // 发 送 头 信息 
imagegif( $ image); // 输 出 图 形 
imagedestroy( $ image) ; // 清 除 资源 


?> 


(2) 画 一 条 线段 
使 用 imageline() 函数 可 以 画 出 一 条 线段 ,语法 格式 如 下 : 


bool imageline(resource $ image, int $xl，int $ yl, int $ x2, int $Y2，int $ color) 
说 明 : imageline( ) 函 数 可 以 在 已 经 创建 的 背景 图 形 $image 上 使 用 $ color 颜色 画 出 一 


条 坐标 从 ($ x1,$ y1) 到 ($ x2, $y2) 的 线段 。 
【 例 8-22】 从 坐标 (0,0) 到 (100,100) 之 间 绘 制 一 条 黑色 的 线段 。 


php 
$ image = imagecreate(800, 800); // 创 建 背景 图 形 
$ background_color = imagecolorallocate( $ image, 255, 255, 255); // 背 景色 设 为 白色 
$ black = imagecolorallocate( $ image, 0,0,0); // 定 义 黑色 
imageline( $ image, 0,0,100,100, $ black); // 画 一 条 黑色 的 线段 
header( "Content - type: image/png"); // 发 送 头 信息 
imagepng( $ image); // 输 出 图 形 
imagedestroy( $ image); // 清 除 资源 
?> 


运行 结果 如 图 8-4 所 示 。 
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图 8-4 画 一 条 线段 





(3) 画 一 个 矩形 
绘制 矩形 可 以 使 用 imagerectangle() 函数 来 完成 。 语 法 格式 如 下 : 


bool imagerectangle(resource $ image, int $ x1l, int $ yl, int $ x2, int $ y2, int $ color) 


说 明 : imagerectangle() 函数 在 已 经 创建 的 背景 图 形 $image 上 使 用 $ color 颜色 画 出 
一 个 矩形 ,矩形 的 左上 角 坐 标 为 ($xl, $ y1) , 右 下 角 坐 标 为 ($ x2, $ y2)。 

(4) 画 一 个 椭圆 

使 用 imageellipse() 函 数 可 以 画 出 一 个 椭圆 ,语法 格式 如 下 : 


bool imageellipse ( resource $ image, int $ cx, int $cy, int $w, int $h, int $ color ) 


说 明 : imageellipse() 函 数 在 背景 图 形 $image 上 画 一 个 中 心 坐 标 为 ($cx, $cy) 的 椭 
圆 。$w 和 $b 分别 指 定 了 椭圆 的 宽度 和 高 度 ,椭圆 线条 的 颜色 由 $ color 指定 。 当 椭圆 的 
宽度 和 高 度 相等 时 , 画 出 的 将 是 一 个 圆 。 
【 例 8-23】 使 用 imageellipse() 函数 画 一 个 椭圆 和 一 个 圆 。 
<?php 
$ image = imagecreate(500, 300); // 创 建 背景 图 形 
$ background = imagecolorallocate( $ image,255,255,255); // 背 景色 设 为 白色 
$ red = imagecolorallocate( $ image, 255,0,0); // 定 义 红色 
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imageellipse( $ image, 100, 100, 200, 100, $ red); // 画 一 个 椭圆 
imageellipse( $ image, 200, 100, 200, 200, $ red); // 画 一 个 圆 






header( "Content — type: image/gif"); // 发 送 头 信息 

imagegif( $ image); // 输 出 图 形 

imagedestroy( $ image); // 清 除 资源 
?> 


运行 结果 如 图 8-5 所 示 。 
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图 8-5 画 一 个 椭圆 和 一 个 圆 


(5) 画 一 个 椭圆 弧 

imageellipse() 函数 用 于 创建 一 个 完整 的 椭圆 ,如 果 只 要 创建 一 个 椭圆 弧 , 可 以 使 用 
imagearc() 函数 。 语 法 格式 如 下 : 

bool imagearc(resource $ image, int $cx, int $cy, int $w, int $h, int $s, int $e int $ color) 

说 明 : imagearc() 图 数 以 坐标 ($cx, $cy) 为 中 心 在 背景 图 形 $ image 上 夯 一 个 椭圆 
弧 。$w 和 $h 分 别 指定 了 椭圆 的 宽度 和 高 度 , 当 宽度 和 高 度 相等 时 , 画 出 来 的 是 圆 绝 。 起 
始 和 结束 点 用 $s 和 $e 参 数 以 角度 指定 。 以 中 心 点 为 原点 作 坐标 系 ,中 心 点 右边 的 横 轴 为 


0 , 按 顺 时 针 方 向 绘画 。 

【 例 8-24】 imagearc( ) 函数 的 用 法 示例 。 

<?php 
$ image = imagecreate(500, 300); // 创 建 背景 图 形 
$ background = imagecolorallocate( $ image,255,255,255); // 背 景色 设 为 白色 
$ red = imagecolorallocate( $ image, 255,0,0); // 定 义 红 色 
$ green = imagecolorallocate( $ image, 0,255,0); // 定 义 绿色 
$ blue = imagecolorallocate( $ image, 0, 0,255); // 定 义 蓝 色 
imagearc( $ image, 100, 100, 150, 150, 0, 180, $ red); // 用 红色 画 一 个 半圆 弧 
imagearc( $ image, 200, 100, 150, 150, 0, 360, $ green); // 用 绿色 画 一 个 圆 
imagearc( $ image, 300, 100, 200, 150, 90, 180, $ blue); // 用 蓝 色 画 一 个 椭圆 弧 
header( "Content — type: image/gif"); // 发 送 头 信息 
imagegif( $ image); // 输 出 图 形 
imagedestroy( $ image); // 清 除 资源 


?> 


运行 结果 如 图 8-6 所 示 。 
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图 8-6 imagearc() 函数 的 用 法 
(6) 画 一 个 多 边 形 
使 用 imagepolygon() 函 数 可 以 画 出 一 个 多 边 形 , 语 法 格式 如 下 : 
bool imagepolygon(resource $ image, array $ points, int $ num points, int $ color) 
说 明 : imagepolygon() 函数 在 背景 图 形 $image 中 创建 一 个 多 边 形 。$ points 是 一 个 


数组 ,包含 多 边 形 各 个 顶点 的 坐标 , 即 $ points[0] 王 x0, $points[1] 王 y0, $points[2] 一 
x1,，$ points[3]=yl, 以 此 类 推 , $num_points 是 顶点 的 坐标 , $ color 为 多 边 形 线条 的 


颜色 。 

【 例 8-25】 绘制 一 个 五 边 形 。 

<?php 
$ image = imagecreate(200, 200); // 创 建 背景 图 形 
$ background = imagecolorallocate( $ image,255,255, 255); // 背 景色 设 为 白色 
$ blue = imagecolorallocate( $ image, 0, 0,255); // 定 义 蓝 色 
$ coords =array(100, 25, 24, 80,53, 170, 147, 170, 176,80); // 定 义 顶 点 坐标 
imagepolygon( $ image, $ coords,5, $ blue); // 画 出 五 边 形 
header( "Content - type: image/gif"); // 发 送 头 信息 
imagegif( $ image); // 输 出 图 形 
imagedestroy( $ image); // 清 除 资源 

?> 

2. 输出 文本 

(1) 输出 一 个 字符 


使 用 imagechar() 函数 可 以 在 背景 图 形 上 水 平 输出 一 个 字符 ,语法 格式 如 下 : 

bool imagechar(resource $ image, int $ font, int $x, int $y, string $c, int $ color) 

说 明 : 函数 用 颜色 $ color 将 字符 $c 画 到 背景 图 形 $image 的 ($x, $y) 坐 标 处 。 如 
果 $c 是 一 个 字符 串 , 则 只 输出 第 一 个 字符 。$ font 表示 字符 串 的 字体 ,如 果 值 为 1 一 5 中 
的 一 个 数 , 则 使 用 内 置 字体 , 值 为 5 时 字体 最 大 ,为 1 时 字体 最 小 。 例 如 : 


imagechar( $ image,5,50,50, 'C', $ color); 
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(2) 输出 字符 串 
使 用 imagestring() 函 数 可 以 在 已 经 创建 的 背景 图 形 上 输出 字符 串 , 语 法 格式 如 下 : 


bool imagestring(resource $ image, int $ font, int $x, int $y, string $s, int $ color) 


说 明 : 函数 用 颜色 $ color 将 字符 串 $s 画 到 背景 图 形 $image 的 ($x, $y) 坐 标 处 (这 
是 字符 串 左 上 角 坐 标 ) 。 

(3) 使 用 指定 字体 输出 字符 串 

使 用 imagettftext() 函 数 可 以 在 输出 字符 的 同时 指定 字体 ,并 根据 参数 的 不 同 输出 不 同 
角度 的 字符 串 ,语法 格式 如 下 : 

array imagettftext( resource $ image, float $ size, float $angle, int $x, int $y, int $color, 

string $ fontfile, string $ text) 

说 明 : 本 函数 用 颜色 $ color 将 字符 串 $ text 输出 到 背景 图 形 $image 的 ($x, $y) 坐 
标 处 ,输出 字符 串 时 ,可 以 指定 字体 的 大 小 $ size, 指 定 字体 的 角度 $angle( 水 平时 角度 值 为 
0, 沿 逆 时 针 变 大 ) ,指定 想 要 使 用 的 TrueType 的 字体 文件 $ fontfile。 

【 例 8-26】 以 不 同 角度 输出 字符 串 ,并 指定 字体 。 


<?php 
$ image = imagecreate(200, 200); // 创 建 背景 图 形 
$ background = imagecolorallocate( $ image, 255,255, 255); // 背 景色 设 为 白色 
$ grey = imagecolorallocate( $ image, 128, 128, 128); // 定 义 灰色 
$ text = 'Testing...'; // 初 始 化 字符 串 
$ font = 'C:\WINDOWS\Fonts\simhei. ttf '; // 字 体 文件 


imagettftext( $ image, 20, 0, 10, 150,，$ grey，$ font，$ text);  // 水 平 输出 字符 串 $ text 
imagettftext( $ image, 20, 45, 10,140, $ grey, $ font, $ text); 
// 以 45` 角 输出 字符 串 $ text 


header("Content - type: image/gif"); // 发 送 头 信息 

imagegif( $ image) // 输 出 图 形 

imagedestroy( $ image) ; // 清 除 资源 
?> 


运行 结果 如 图 8-7 所 示 。 
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8-7 使 用 指定 字体 输出 字符 串 


(4) 输出 中 文字 符 
中 文字 符 不 可 以 使 用 imagettftext() 函数 在 图 片 中 直接 输出 ,如 果 要 输出 中 文字 符 , 需 
要 先 使 用 iconv() 函数 对 中 文字 符 进行 编码 ,语法 格式 如 下 ， 


string iconv ( string $ in_charset，string $ out_charset，string $ str ) 


说 明 : 参数 $ in_charset 是 中 文字 符 原来 的 字符 集 , $ out_charset 是 编码 后 的 字符 集 ， 
$ str 是 需要 转换 的 中 文字 符 串 。 函 数 最 后 返回 编码 后 的 字符 串 。 这 时 使 用 imagettftext() 
函数 就 可 以 在 图 片 中 输出 中 文 了 。 

【 例 8-27】 在 图 片 中 输出 中 文 。 


<?php 
header( "Content — type: image/gif"); 
$ image = imagecreate(500, 500); // 创 建 背景 图 形 
$ background = imagecolorallocate( $ image, 255,255, 255); // 背 景色 为 白色 
$ red = imagecolorallocate( $ image, 0, 255, 0); // 定 义 绿色 
$ text = "汕头 职业 技术 学 院 "; 
$ font = 'C:\WINDOWS\Fonts\simhei. ttf '; // 字 体 文件 
$ codetext = iconv("GB2312", "UTF - 8", $ text); // 对 中 文 进行 编码 
imagettftext( $ image, 20, 0, 10, 150, $ red, $ font, $ codetext); 
// 水 平 输出 字符 串 $ codetext 
imagegif( $ image); // 输 出 图 形 
imagedestroy( $ image) ; // 清 除 资 源 

?> 


运行 结果 如 图 8-8 所 示 。 
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图 8-8 在 图 片 中 输出 中 文 


3. 绘制 带 填充 色 的 几何 图 形 

在 实际 的 绘图 过 程 中 ,经 常 需要 对 图 形 中 的 某 一 区 域 填充 颜色 ,这 样 图 形 才 会 变 得 更 加 
美观 。 在 PHP 中 可 以 使 用 imagefill() 函数 对 某 一 区 域 进 行 颜色 填充 ,语法 格式 如 下 : 

bool imagefill(resource $ image, int $ x, int $y, int $ color ) 

说 明 : 函数 在 背景 图 形 $image 的 坐标 ($x, $y) 处 用 颜色 $color 执行 区 域 填充 , 即 与 
($x, $y) 点 颜色 相同 且 相 邻 的 点 都 会 被 填充 上 该 颜色 。 例 如 : 


<?php 
$ image = imagecreatetruecolor( 100, 100); // 创 建 背景 图 形 ,默认 为 黑色 
$ red = imagecolorallocate( $ image, 255,0,0); // 设 为 红色 
imagefill( $ image, 0,0, $ red); // 填 充 红色 


header( "Content — type: image/gif"); 
imagegif( $ image); 
imagedestroy( $ image) ; 

?> 




















第 8 章 。PHP 常 用 功能 模块 〈143 
上 面 代码 实现 的 功能 是 将 整个 背景 图 形 的 颜色 填充 为 红色 。 
使 用 imagefill() 函数 填充 颜色 时 要 计算 填充 点 ,这 是 一 件 很 麻烦 的 事 。PHP 可 以 在 画 
几何 图 形 时 就 将 几何 图 形 填 充 为 指定 颜色 。 
(1) 画 一 个 矩形 并 填 色 
使 用 imagefilledrectangle() 函数 可 以 画 一 个 矩形 ,并 使 用 指定 颜色 填充 该 矩形 。 语 法 
格式 如 下 : 


bool imagefilledrectangle( resource $ image, int $ x1l, int $ yl, int $ x2, int $ y2, int $color ) 


说 明 : imagefilledrectangle() 函数 的 功能 和 参数 结构 与 imagerectangle() 函数 类 似 ,不 
同 之 处 在 于 , imagerectangle ( ) 函数 的 $color 参数 指定 的 是 矩形 线条 的 颜色 ， 
imagefilledrectangle( ) 函数 的 $ color 参数 指定 的 是 整个 矩形 区 域 的 颜色 。 

【 例 8-28】 画 一 个 矩形 并 填 色 。 





<?php 
$ image = imagecreatetruecolor(200, 200); 
$ white = imagecolorallocate( $ image, 255,255,255); // 定 义 白色 
$ grey = imagecolorallocate( $ image, 128, 128, 128); // 定 义 灰色 
imagefill( $ image, 0,0, $ white); // 背 景色 设 为 白色 
imagefilledrectangle( $ image, 10, 10, 150,150, $ grey) ; // 画 一 个 矩形 , 并 填充 灰色 
header( 'Content — type: image/gif'); 
imagegif( $ image); // 输 出 图 形 
imagedestroy( $ image); 

?> 


(2) 画 一 个 椭圆 并 填 色 

使 用 imagefilledellipse() 函数 可 以 在 已 经 创建 的 图 形 上 画 一 个 椭圆 ,并 使 用 指定 颜色 
进行 填充 。 语 法 格式 如 下 : 

bool imagefilledellipse(resource $ image, int $cx, int $cy, int $w, int $h, int $ color) 

说 明 : imagefilledellipse() 函 数 的 功能 与 参数 结构 与 imageellipse( ) 函数 类 似 , 只 不 过 
imagefilledellipse( ) 函数 的 $ color 参数 指定 的 是 整个 椭圆 区 域 的 填充 色 。 

(3) 画 一 个 椭圆 弧 并 填 色 

函数 imagefilledarc() 可 以 画 一 个 椭圆 弧 并 填充 颜色 ,语法 格式 如 下 : 


bool imagefilledarc(resource $ image, int $cx, int $cy, int $w, int $h, int $s, int $e@, 
int $ color, int $ style) 


说 了 明 : imagefilledarc( ) 函数 的 功能 和 参数 结构 与 imagearc() 函 数 类 似 , 只 不 过 
imagefilledarc( ) 函 数 比 imagearc() 函数 多 了 一 个 $ style 参数 。 


8.3.4 图 形 的 具体 操作 
1. 颜色 处 理 


(1) 指定 颜色 填充 


使 用 imagefilltoborder( ) 函数 可 以 为 指定 点 进行 颜色 填充 ,如 果 遇 到 指定 颜色 的 边界 ， 
则 停止 填充 。 语 法 格式 如 下 : 


bool imagefilltoborder(resource $ image, int $ x, int $y, int $ border, int $ color) 


说 明 : 该 函数 从 坐标 ($x，$y) 开 始 用 $ color 颜色 执行 区 域 填充 ,直到 磁 到 颜色 为 
$ border 的 边界 为 止 。 边 界 内 的 所 有 颜色 都 会 被 填充 。 

(2) 定义 透明 色 

使 用 imagecolorallocatealpha() 函数 也 可 以 为 指定 的 图 形 分 配 颜 色 , 还 可 以 设置 颜色 的 
透明 度 。 语 法 格式 如 下 : 


int imagecolorallocatealpha ( resource $ image, int $ red, int $ green, int $ blue, int $ alpha ) 


说 了 明 : imagecolorallocatealpha ( ) 函数 比 imagecolorallocate ( ) 函数 多 了 一 个 参数 
$ alpha, 这 个 参数 就 用 于 设置 颜色 的 透明 度 , 其 值 为 0~127。0 表示 完全 不 透明 ,127 表示 
完全 透明 。 

【 例 8-29】〗 设置 颜色 的 透明 度 示 例 。 

<?php 


$ image = imagecreatetruecolor(200, 200); 
imagefill( $ image, 0, 0, imagecolorallocate( $ image,255,255,255)); 


$ red = imagecolorallocatealpha( $ image, 255,0,0,60); // 红 色 , 透 明度 为 60 
$ blue = imagecolorallocatealpha( $ image,0,0,255,60); // 蓝 色 , 透 明度 为 60 
imagefilledellipse( $ image, 50, 50, 100, 100, $ red) ; // 画 红色 圆 
imagefilledellipse( $ image, 70, 70, 100,100, $ blue); // 画 蓝 色 贺 


header( 'Content — type: image/gif'); 
imagegif( $ image); 
imagedestroy( $ image); 

3 


2. 复制 图 片 的 一 部 分 

使 用 imagecopy() 函 数 能 够 复制 图 片 的 一 部 分 到 另 一 个 图 片 中 ,语法 格式 如 下 : 

bool imagecopy(resource $ dst_im, resource $ src_im, int $dst_x, int $dst_y, int $ src_x, 

int $ src_y, int $ src_w, int $ src_h) 

注意 : 将 $src_im 中 坐标 从 ($src_x，$src_y) 开 始 ,宽度 为 $src_w、 高 度 为 $src_h 
的 一 部 分 复制 到 $ dst_im 中 坐标 为 ($dst_x，$ dst_y) 的 位 置 上 。 

【 例 8-30】 复制 图 片 的 一 部 分 到 另 一 张 图 片 中 (图 片 位 于 当前 目录 下 的 images 目 
录 中 )。 

新 建 EX8-30. php 文件 ,输入 以 下 代码 。 

<?php 

header( "Content - type: image/jpeg"); // 发 送 头 信息 


$ imagel = imagecreatefromjpeg(" images/EX8_30_n1. jpg" ); // 创 建 图 形 
$ image2 = imagecreatefromjpeg(" images/EX8_30_n2. jpg" ); 





imagecopy( $ imagel, $ image2,50,5,50,0,160,160); // 复 制图 形 的 一 部 分 
imagejpeg( $ imagel); // 输 出 图 形 $ imagel 


imagedestroy( $ imagel ); 
imagedestroy( $ image2); 
?> 
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运行 结果 如 图 8-9 所 示 。 

3. 复制 图 片 并 调整 大 小 

使 用 imagecopyresized() 函 数 也 可 以 实现 imagecopy() 函 
数 的 功能 ,并 可 以 对 复制 的 图 片 大 小 进行 调整 。 语 法 格式 
如 下 : 


bool imagecopyresized( resource $ dst_ image, resource $ src_ 








image, int $dst_x, int $dst_y, int $ src_x, int $ src_y, int 

$dstw,int $dst_h, int $ src_w int $ src_h) 

注意 : imagecopyresized() 函 数 比 imagecopy() 函 数 多 了 两 
个 参数 : $dst_w 种 dst_h, 这 两 个 参数 表示 将 复制 的 图 片 宽 
度 和 高 度 分 别 调整 为 $ dst_w 和 $dst_h, 即 实现 了 图 片 的 缩放 图 8.9 复制 图 片 的 部 分 
功能 。 例 如 : 





imagecopyresized( $ imagel, $ image2,50,5,50,0,50,50,160,160) 

以 上 代码 是 对 $image2 从 坐标 (50,0) 开 始 , 截 取 宽 为 160、 高 为 160 的 一 部 分 图 形 ,使 
之 缩小 为 宽 为 50、 高 为 50 之 后 ,再 复制 到 $imagel 中 坐标 (50,5) 开 始 的 位 置 上 。 

4. 旋转 图 像 

使 用 imagerotate() 函 数 可 以 将 图 像 旋转 给 定 角度 ,语法 格式 如 下 : 


resource imagerotate(resource $ src_im, float $angle, int $bgd_color [, int $ ignore_ 


transparent ] ) 

注意 : 参数 $ src_im 是 指定 的 图 像 ,$angle 是 指定 的 旋转 角度 ,$bgd_color 指定 了 旋 
转 后 没有 履 盖 到 的 部 分 的 颜色 。 旋 转 的 中 心 是 图 像 的 中 心 ,旋转 后 的 图 像 会 按 比 例 缩小 以 
适合 目标 图 像 的 大 小 ,边缘 不 会 被 剪 去 。 

【 例 8-31】 将 图 像 旋转 45° 后 显示 。 


<?php 
$ filename = 'images/fox. jpg'; // 指 定 一 张 图 片 
$ degrees = 45; // 旋 转 的 角度 
header( 'Content — type: image/jpeg'); 
$ image = imagecreatefromjpeg( $ filename); // 根 据 已 知 图 片 创建 图 形 
$ rotate = imagerotate( $ image, $ degrees, 0,0); // 旋 转 图 片 


imagejpeg( $ rotate); 
imagedestroy( $ image) ; 
?> 


说 明 : 旋转 时 将 参数 $bgd_color 设 为 0 表示 旋转 后 没有 覆盖 到 的 部 分 用 黑色 填充 。 
8.3.5 其 他 的 图 形 函 数 


1. 取得 图 形 信息 
之 前 介绍 的 imagesx() 和 imagesy() 函 数 可 以 获取 图 形 的 宽 和 高 ,getimagesize() 函数 
可 以 获取 指定 图 形 的 尺寸 、 宽 度 、 高 度 和 类 型 等 信息 。 该 函数 将 这 些 信息 以 数组 的 形式 返 








回 ,如 果 指 定 的 图 形 不 是 有 效 的 文件 , 则 返回 False。 例 如 : 


<?php 
$ message = getimagesize(" images/fox. jpg" ); 
print_r( $ message); 
/* 输出 结果 
Array ( [0] => 391 [1] => 220 [2] =>2 [3] => width="391" height = "220" [bits] => 
8 [channels] =>3 [mime] => image/jpeg ) 
# 
> 


说 明 : 键 名 0 的 键 值 表示 图 形 的 宽度 , 键 名 1 的 键 值 表示 图 形 的 高 度 , 键 名 2 的 键 值 表 
示 图 形 的 类 型 (1 为 GIF,2 为 JPG,3 为 PNG,4 为 SWF,5 为 PSD,6 为 BMP), 键 名 3 的 键 
值 是 一 个 字符 串 , 键 名 bits 的 键 值 表 示 图 形 颜色 的 位 数 , 键 名 channels 的 键 值 3 表示 图 形 
是 RGB 图 形 ; 键 名 mime 的 键 值 表示 图 形 的 类 型 信息 。 


2. 设 定 画 线 
使 用 imagesetthickness() 函数 可 以 设置 画 几 何 图 形 时 画 线 的 宽度 ,语法 格式 如 下 : 


bool imagesetthickness(resource $ image, int $ thickness) 


注意 : 该 函数 将 画 线 宽度 设 为 $ thickness 个 像素 。 
【 例 8-32】 设置 画 线 的 宽度 示例 。 


<?php 
$ image = imagecreatetruecolor( 400, 400); 
imagefill( $ image, 0, 0, imagecolorallocate( $ image,255,255, 255)); 
$black = imagecolorallocate( $ image,0, 0,0); 
imagesetthickness( $ image, 5); 
imageline( $ image, 0, 200, 300, 0, $ black); 
header( "Content - type: image/gif"); 
imagegif( $ image); 
imagedestroy( $ image); 
?> 


8.3.6 实例 一 一 自动 生成 验证 码 


【 例 8-33】 在 制作 一 个 用 户 留 言 页 面 时 需要 进行 验证 ,本 例 自动 生成 验证 码 图 片 , 用 
户 输入 验证 码 图 片 中 字符 ,系统 进行 验证 。 
新 建 EX8-33a. php 页 面 , 显 示 用 户 界 面 。 


<! DOCTYPE htm] > 
<html> 
<head> 
<title > 留言 页 面 </title> 
</head > 
<body> 
< form method= "post" action = ""> 
验证 码 : < input type = "text”size = "10”name = "check"> 
< img src = "EX8— 33b. php"> 
< input type = "submit" name = "ok" value = "提交 "> 
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<?php 
session_start(); 
if(isset( $ _POST[ ‘ok'])) 
{ 
$ checkstr = $ _SESSION[ 'string ']; 
$ str= $ _POST[ 'check']; 
if(strcasecmp( $ str, $ checkstr) == 0) 
echo "< script >alert( ' 验 证 码 输入 正确 ! ');</script >"; 
else 
echo "< script >alert( ' 输 入 错误 ! ') ;</script >"; 








?> 


新 建 EX8-33b. php 页 面 ,用 于 产生 验证 码 图 片 中 的 字符 。 


<?php 
session_start(); 
header( 'Content ~ type: image/gif'); 
$ image_w = 100; 
$ image_h= 25; 
$ number = range( 0,9); 
$ character = range("2", "A"); 
$ result = array_merge( $ number, $ character); 
$ string=""; 
$ len= count( $ result); 
for( $i=0;$i<4;$ i+t+) 


€ 





$ new_number[ $ i] = $ result[rand(0, $ len—1)]; 
$ string= $ string. $ new_number[ $ i]; 
} 
$ _SESSION[ 'string'] = $ string; 
$ check_image = imagecreate truecolor( $ image_w, $ image_h); 
$ white = imagecolorallocate( $ check_image, 255, 255, 255); 
$ black = imagecolorallocate( $ check_image, 0, 0, 0); 
imagefil1( $ check_image, 0,0, $ white) ; 
for( $i=0;$i<100; $ i++) 
{ 
imagesetpixel( $ check_image, rand(0, $ image_w), rand(0, $ image_h), $ black); 
} 
for( $i=0;$i<count( $new_number); $ i++) 
{ 
$x=mt_rand(1,8) + $ image_w* $ i/4; 
$y=mt_rand(1, $ image_h/4); 
$ color = imagecolorallocate( $ check_image, mt_rand(0, 200), 
mt_rand(0,200),nmt_rand(0,200)); 
imagestring( $ check_image,5, $ x, $y, $ new_number[ $ i], $ color); 
} 


imagepng( $ check_image); 
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运行 结果 如 图 8-10 所 示 。 








全 0 





验证 码 : 














来 自 网 页 的 消息 ”区 


LN ai 





图 8-10 ”提交 验证 码 
8.4 项 目 实 训 


实 训 1 删除 指定 路 径 中 的 非 空 文件 夹 


实 训 目的 

(1) 了 解 目 录 操 作 的 步 又 。 

(2) 学 会 获取 指定 路 径 中 的 文件 名 和 文件 夹 名 。 

(3) 学 会 判断 一 个 路 径 是 目录 路 径 还 是 文件 路 径 。 

(4) 掌握 删除 非 空 文件 夹 的 方法 。 

实 训 要 求 

在 sx8 目录 下 创建 sx8-1. php 网 页 ,要求 在 下 拉 列 表 框 中 , 列 出 sx8 目录 包含 的 所 有 文 
件 夹 ,如 图 8-11 所 示 。 如 果 用 户 选 择 任意 一 个 文件 夹 ( 包 括 非 空 文件 夹 ,如 com), 并 单 击 
“删除 ”按钮 ,就 能 删除 该 文件 夹 。 


实 训 2 文件 的 上 传 


实 训 目的 

(1) 了 解 文件 上 传 的 步骤 。 

(2) 学 会 使 用 预定 义 变量 $_FILES 提取 客户 端 文件 的 信息 。 

(3) 学 会 使 用 move_uploaded_file() 将 客户 端 文件 上 传 到 服务 器 中 。 

实 训 要 求 

在 sx8 目录 下 创建 sx8-2. php 网 页 ,将 客户 端 上 传 的 文件 存放 到 sx8\upload 目录 下 ,并 
输出 上 传 文件 的 名 称 、 类 型 大小。 运行 结果 如 图 8-12 所 示 。 














到 区 ..，] [上传 文件 
文件 名 称 : feeevert de 


文件 类 型 
文件 大 小 ，323.5KB 
图 8-11 列 出 所 有 文件 夹 图 8-12 文件 上 传 结果 
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实 训 3 ”将 服务 器 的 日 期 时间 .星期 几 信息 显示 在 网 页 中 


实 训 目 的 

(1) 了 解 时 区 的 设置 。 

(2) 掌握 date 函数 的 用 法 。 

实 训 要 求 

在 sx8 目录 下 创建 sx8-3. php 网 页 ,将 服务 器 的 日 期 \ 时 间 、 星 期 几 信息 按 图 8-13 所 示 
显示 在 网 页 中 。 








2016 年 12 月 
16 日 
星期 五 

















图 8-13 显示 日 期 信息 


思考 与 练习 


一 、 填空 题 

1. 在 "文件 句柄 三 fopen(" 文 件 路 径 ", $ mode)”" 语 句 中 ,文件 路 径 可 以 是 盘 符 ,协议 开 
头 的 路 径 ,也 可 以 是 路 径 。 

2. 语句 “数组 名 二 file(" 文 件 路 径 ")” 的 功能 是 将 整个 文件 内 容 读 取 到 一 维 数组 中 , 文 
件 中 的 读 取 到 数组 的 一 个 元 素 中 。 用 于 将 一 个 网 页 的 按 原 格式 显示 到 浏 
览 器 中 。 

3. 获取 当前 时 间 戳 的 语句 是 ,获取 系统 当前 的 日 期 ,时间 、 星 期 几 的 语句 





是 





二 、 简 答 题 

. 常用 目录 文件 操作 函数 有 哪些 ? 具体 功能 各 是 什么 ? 
.常用 日 期 时 间 函 数 有 哪些 ? 具体 功能 各 是 什么 ? 
.常用 图 片 处 理 函 数 有 哪些 ? 具体 功能 各 是 什么 ? 

. 绘制 直线 、 椭 圆 、 点 分 别 使 用 哪 几 个 图 形 处 理 函 数 ? 


Dr 











为 了 防止 网 站 存在 明显 的 可 被 攻击 漏洞 ,需要 特别 注意 以 下 几 点 。 

(1) 软件 漏洞 。 包 括 Web 服务 器 软件 ,数据库 服务 器 软件 .脚本 编程 语言 的 漏洞 。 
(2) 用 户 恶 意 输入 。 必 须 先 检查 这 些 数 据 , 并 过 滤 有 可 能 对 系统 造成 破坏 的 数据 。 
(3) 未 能 妥善 验证 用 户 身份 。 


。 了解 PHP 的 安全 配置 。 

。 了 解 SQL 注入 攻击 的 原理 和 防范 措施 。 
。 了 解 跨 站 脚本 攻击 的 原理 和 防范 措施 。 
。 掌握 身份 认证 系统 的 设计 和 实现 。 


9.1 安全 配置 PHP 


PHP 的 配置 文件 是 php. ini, 该 文件 位 于 C:\Windows 目录 下 , 它 提 供 了 很 多 配置 参 
数 , 通 过 合理 配置 可 大 大 提高 PHP 网 站 的 安全 级 别 , 尤 其 可 防止 SQL 注入 攻击 。 


9.1.1 安全 模式 的 配置 

(1) 打开 PHP 的 安全 模式 

PHP 的 安全 模式 是 个 非常 重要 的 内 嵌 的 安全 机 制 ,能 够 控制 一 些 PHP 中 的 函数 ,比如 
system(), 同 时 对 很 多 文件 操作 函数 进行 了 权限 控制 ,也 不 允许 对 某 些 关键 文件 进行 操作 ， 
比如 /etc/passwd。 但 是 默认 的 php. ini 是 没有 打开 安全 模式 的 ,打开 方式 如 下 : 

safe_mode = on 

(2) 用 户 组 安全 

当 safe_mode 打开 时 ,safe_mode_gid 被 关闭 , 则 PHP 脚本 能 够 对 文件 进行 访问 , 且 相 
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同 组 的 用 户 也 能 够 对 文件 进行 访问 。 建 议 设置 为 : 

Safe_mode_ gid = off 

如 果 不 进行 设置 ,可 能 就 无 法 对 服务 器 网 站 目录 下 的 文件 进行 操作 了 。 

(3) 安全 模式 下 执行 程序 主 目录 

如 果 安 全 模式 打开 了 ,要 执行 某 些 程序 时 ,可 以 指定 要 执行 程序 的 主 目录 

safe_mode_exec_dir =C:/WAMP/bin 

在 一 般 情况 下 是 不 需要 执行 什么 程序 的 ,所 以 推荐 不 要 执行 系统 程序 目录 ,可 以 指向 一 
个 目录 ,然后 把 需要 执行 的 程序 复制 过 去 ,比如 : 


safe_mode_exec_dir =C:/WHW/TOOL 


一 般 情况 下 ,推荐 只 指向 本 网 站 网 页 目录 : 

safe_mode_exec_dir = C:/WRMP/NWNN 

(4) 安全 模式 下 包含 文件 

如 果 要 在 安全 模式 下 包含 某 些 公共 文件 , 则 需要 修改 一 下 选项 : 

safe_mode_include_dir =C:/WAMP/www/include/ 

这 在 一 般 文件 中 都 已 包含 ,在 PHP 脚本 中 已 经 写 好 ,可 以 根据 具体 需要 进行 设置 。 

9.1.2 其 他 与 安全 有 关 的 参数 配置 

(1) 控制 PHP 脚本 能 访问 的 目录 

使 用 open_basedir 选项 能 够 控制 PHP 脚本 只 能 访问 指定 的 目录 ,这 样 能 够 避免 PHP 
脚本 访问 不 应 该 访问 的 文件 ,在 一 定 程度 上 限制 了 PHP Shell 的 危害 ,一 般 可 以 设置 为 只 能 
访问 网 站 目录 : 

open_basedir =C:/WAMP /NNW 

(2) 关闭 危险 函数 

如 果 打 开 了 安全 模式 ,那么 函数 禁止 是 可 以 不 需要 的 ,但 是 为 了 安全 还 是 考虑 进去 。 比 
如 ,不 希望 执行 包括 system() 等 在 内 的 PHP 函数 ,或 者 能 够 查看 PHP 信息 的 phpinfo() 等 
函数 ,就 可 以 禁止 它们 : 

disable_functions = system, passthru, exec, shell_exec, popen, phpinfo 

如 果 要 禁止 任何 文件 和 目录 的 操作 ,那么 可 以 关闭 很 多 文件 操作 : 


disable_functions = chdir, chroot, dir, getcwd, opendir, readdir, scandir, fopen, unlink, delete, 
Copy, mkdir, rmdir, rename, file, file_get_contents, fputs, fwrite, chgrp, chmod, chown 


以 上 只 是 列 了 部 分 比较 常用 的 文件 处 理 函数 .就 能 够 抵制 大 部 分 的 PHP Shell 了 。 
(3) 关闭 PHP 版 本 信息 
为 了 防止 黑客 获取 服务 器 中 PHP 版 本 的 信息 ,可 以 关闭 该 信息 : 


expose_php = Off 


这 样 黑 客 在 执行 telnet www. xxx. com 80 命令 时 ,将 无 法 看 到 PHP 版 本 的 信息 。 

(4) 关闭 注册 全 局 变量 

在 PHP 中 提交 的 变量 ,包括 使 用 POST 或 者 GET 提交 的 变量 ,都 将 自动 注册 为 全 局 
变量 ,能 够 直接 访问 ,这 是 对 服务 器 非常 不 安全 的 ,所 以 不 能 让 它 注册 为 全 局 变量 ,把 注册 全 
局 变量 选项 关闭 : 

register_globals = Off 


当然 ,如 果 这 样 设置 了 ,那么 获取 对 应 变量 时 就 要 采用 合理 方式 ,比如 ,获取 GET 提交 
的 变量 var, 就 要 用 $ _GET[ 'var '] 来 获取 。 

(5) 打开 magic_quotes_gpc 防止 SQL 注入 

SQL 注入 是 非常 危险 的 问题 , 轻 则 网 站 后 台 被 入 侵 , 重 则 整个 服务 器 沦陷 ,所 以 一 定 要 
小 心 。php. ini 中 有 一 个 设置 : 

magic_quotes_gpc = Off 

这 个 默认 是 关闭 的 ,如 果 它 打开 后 将 自动 把 用 户 提交 对 SQL 的 查询 进行 转换 ,比如 把 
' 转 为 \ 等 ,这 对 防止 SQL 注入 有 重大 作用 。 所 以 推荐 设置 如 下 : 

magic_quotes_gpc = On 

(6) 错误 信息 控制 

一 般 PHP 在 没有 连接 到 数据 库 或 者 其 他 情况 下 会 有 提示 错误 ,一 般 错误 信息 中 会 包 
含 PHP 脚本 当前 的 路 径 信息 或 者 查询 的 SQL 语句 等 信息 。 这 类 信息 提供 给 黑客 后 ,是 不 
安全 的 ,所 以 一 般 服务 器 建议 禁止 错误 提示 : 

display_errors = Off 

如 果 想 要 显示 错误 信息 ,一 定 要 设置 显示 错误 的 级 别 , 比 如 只 显示 警告 以 上 的 信息 : 

error_reporting = E_WARNING & E_ERROR 

当然 ,还 是 建议 关闭 错误 提示 。 

(7) 错误 日 志 

建议 在 关闭 display_errors 后 能 够 把 错误 信息 记录 下 来 ,便于 查找 服务 器 错误 的 原因 : 

log_errors = On 

同时 也 要 设置 错误 日 志 存放 的 目录 ,建议 与 Apache 的 日 志 存 在 一 起 : 

error_log = C:/WAMP /local/apache2/logs/php_error. log 


注意 : 必须 允许 Apache 用 户 的 和 组 具有 写 的 权限 。 

(8) 脚本 最 大 执行 时 间 max_execution_time 

php. ini 中 默认 的 最 长 执行 时 间 是 30 秒 , 这 由 php. ini 中 的 max_execution_time 变量 
指定 ,倘若 你 有 一 个 需要 颇 多 时 间 才 能 完成 的 工作 ,方法 是 修改 php. ini 中 max_execution_ 
time 的 数值 。 


9.1.3 Apache 的 降 权 运行 
在 Windows 平台 下 搭建 的 Apache 默认 运行 是 system 权限 ,下 面 将 讲述 如 何 给 
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Apache 降低 权限 。 


net user apache apche /add 
net localgroup users apache /del 


这 样 建 立 了 一 个 不 属于 任何 组 的 用 户 apache。 
打开 计算 机 管理 器 , 选 服务 , 单 击 apache 服务 的 属性 ,选择 log on, 选 择 this account, 填 
和 人 建立 的 账户 和 密码 ,如 图 9-1 所 示 。 重 启 apache 服务 ,apache 运行 在 低 权 限 下 了 。 


wampapache 的 属性 (本 地 计算 机 ) EE 











本 从: 
口 本 地 系统 了 户 ( 
允许 服务 与 桌面 交互 (W) 
国 Hk 记 mm: apache | mse) | 
i FT 
i ns 

















图 9-1 登录 界面 


实际 上 还 可 以 通过 设置 各 个 文件 夹 的 权限 ,让 apache 用 户 只 能 执行 我 们 想 让 它 干 的 事 
情 , 给 每 一 个 目录 建立 一 个 单独 的 、 能 读 写 的 用 户 。 


9.2 SQL 注入 攻击 与 防范 


SQL 注入 就 是 攻击 者 通过 把 SQL 命令 插入 Web 表单 递交 或 输入 域名 或 页 面 请 求 的 
查询 字符 串 , 最 终 达 到 让 后 台数 据 库 执行 恶意 SQL 命令 的 目的 ,并 根据 程序 返回 的 结果 , 获 
得 某 些 攻击 者 想 知道 的 数据 。 


9.2.1 SQL 注入 攻击 原理 及 特点 


(1) SQL 注入 攻击 原理 

SQL 注入 攻击 是 指 通过 构建 特殊 的 输入 作为 参数 传人 Web 应 用 程序 ,而 这 些 输 入 大 
都 是 SQL 语法 里 的 一 些 组 合 ,通过 执行 SQL 语句 进而 执行 攻击 者 所 要 的 操作 ,其 主要 原因 
是 程序 没有 细致 地 过 滤 用 户 输入 的 数据 ,致使 非法 数据 侵入 系统 。 

SQL 注入 可 以 分 为 平台 层 注 入 和 代码 层 注 入 。 前 者 由 不 安全 的 数据 库 配 置 或 数据 库 
平台 的 漏洞 所 致 ; 后 者 主要 是 由 于 程序 员 对 输入 未 进行 细致 过 滤 , 从 而 执行 了 非法 的 数据 
查询 。 

(2) SQL 注入 攻击 的 一 般 步 又 

QO 攻击 者 访问 有 SQL 注入 漏洞 的 网 站 ,寻找 注入 点 。 

@ 攻击 者 构造 注入 语句 ,注入 语句 与 程序 中 的 SQL 语句 结合 生成 新 的 SQL 语句 。 
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@ 新 的 SQL 语句 被 提交 到 数据 库 中 执行 处 理 。 

@ 数据 库 执行 了 新 的 SQL 语句 后 ,引发 SQL 注入 攻击 。 

(3) SQL 注入 攻击 的 特点 

@ 广泛 性 。SQL 注入 攻击 可 以 跨越 Windows、UNIX、Linux 等 各 种 操作 系统 进行 攻 
击 ,其 攻击 目标 非常 广泛 。 只 要 是 使 用 SQL 语言 的 Web 应 用 程序 ,如 果 未 对 输入 的 SQL 
语句 做 严格 的 处 理 都 会 存在 SQL 注入 漏洞 。 

@ 隐蔽 性 。SQL 注入 是 从 正常 的 WWW(80) 端 口 访问 , 它 是 为 HTTP 即 超 文本 传输 
协议 开放 的 ,是 万 维 网 传输 信息 使 用 最 多 的 协议 。 通 过 该 端口 的 数据 都 是 被 防火 墙 所 许可 
的 ,因此 防火 墙 不 会 对 SQL 注入 的 攻击 进行 拦截 ,使 攻击 者 可 以 顺利 地 通过 防火 墙 。 如 果 
管理 员 没有 查看 IIS 日 志 的 习惯 ,可 能 被 入侵 很 长 时 间 都 不 会 发 觉 。 

@ 攻击 时 间 短 。 可 在 短 短 几 秒 到 几 分 钟 内 完成 一 次 数据 窃取 、 一 次 木马 种 植 ,甚至 完 
成 对 整个 数据 库 或 Web 服务 器 的 控制 。 

@ 危害 大 。 目 前 的 电子 商务 等 都 是 基于 Web 的 服务 ,交易 量 巨大 ,一 旦 遭 到 攻击 后 果 
不 堪 设 想 。 另 外 ,是 关于 个 人 信息 的 窃取 ,之 前 的 CSDN 用 户 资料 泄露 就 引起 了 很 大 的 社 
会 反响 。 


9.2.2 SQL 注 人 攻击 的 方法 


(1) 进行 SQL 注入 时 一 般 会 用 到 两 种 方式 ,第 一 种 是 手工 注入 ; 第 二 种 是 工具 注入 。 
SQL 注入 攻击 的 常见 方式 如 表 9-1 所 示 。 
表 9-1 SQL 注入 攻击 的 常见 方式 














方 法 密码 框 中 输入 的 内 容 说 明 
增加 条 件 表达 式 法 ‘or = 适合 于 任何 情况 
插入 注释 符 法 "or 1 一 1 /* 适合 于 任何 情况 
”uni select * from admi 
union 连接 其 他 查询 法 ee | 必须 知道 表 名 和 字段 名 
插入 语句 结束 符 ”i" 构 造 多 查询 | ， ， | 仅 SQL Server 或 Access 中 能 
由 ; drop table admin 兴 
语句 法 使 用 








(2) 修补 SQL 注入 漏洞 的 措施 。 
可 以 使 用 addslashes 函数 对 用 户 输入 的 特殊 字符 加 反 斜 枉 。 例 如 : 


$ userName = addslashes( $ _POST[ "userName" ] ); 


将 php. ini 中 的 magic_quotes_gpe 一 On, 则 上 述 注入 攻击 都 不 会 成 功 。 
使 用 mysql_real_escape_string() 函 数 , 但 在 调用 mysql_real_escape_string() 之 前 , 必 
须 先 连 接 MySQL 数据 库 。 


9.2.3 SQL 注 人 攻击 的 检测 


(1) 动态 SQL 检查 
动态 的 SQL 语句 是 一 个 进行 数据 库 查 询 的 强大 工具 ,但 把 它 和 用 户 输入 混合 在 一 起 就 


第 9 章 ”PHP 安 全 编程 (155 

使 SQL 注入 成 为 可 能 。 将 动态 的 SQL 语句 替换 成 预 编译 的 SQL 或 者 存储 过 程 对 大 多 数 
应 用 程序 是 可 行 的 。 预 编译 的 SQL 或 者 存储 过 程 可 以 将 用 户 的 输入 作为 参数 而 不 是 命令 
来 执行 ,这 样 就 限制 了 入 侵 者 的 行动 。 当 然 , 它 不 适用 于 存储 过 程 中 利用 用 户 输入 来 生成 
SQL 命令 的 情况 。 在 这 种 情况 下 ,用 户 输入 的 SQL 命令 仍 可 能 得 到 执行 ,数据 库 仍 然 存在 
SQL 注入 漏洞 攻击 的 危险 。 

(2) 有 效 性 校 验 

如 果 一 个 输入 框 只 能 包括 数字 ,那么 要 通过 验证 确保 用 户 输入 的 都 是 数字 。 如 果 可 以 
接收 字母 ,就 需要 设置 字符 串 检查 功能 ,检查 是 不 是 存在 不 可 接收 的 字符 。 确 保 应 用 程序 要 
检查 以 下 字符 : 分 号 、 等 号 、 破 折 号 、 括 号 以 及 SQL 关键 字 。 

(3) 数据 表 检 查 

使 用 SQL 注入 漏洞 攻击 工具 软件 进行 SQL 注入 漏洞 攻击 后 ,都 会 在 数据 库 中 生成 一 
些 临 时 表 。 通 过 查看 数据 库 中 最 近 新 建 的 表 的 结构 和 内 容 , 可 以 判断 是 否 曾经 发 生 过 SQL 
注入 漏洞 攻击 。 

(4) 审计 日 志 检查 

在 Web 服务 器 中 如 果 启 用 了 审计 日 志 功 能 , 则 Web Service 审计 日 志 会 记录 访问 者 的 
IP 地 址 .访问 时 间 ,访问 文件 等 信息 ,SQL 注入 漏洞 攻击 往往 会 大 量 访问 某 一 个 页 面 文件 
(存在 SQL 注入 点 的 动态 网 页 ) ,审计 日 志文 件 会 急剧 增加 ,通过 查看 审计 日 志文 件 的 大 小 
以 及 审计 日 志文 件 中 的 内 容 , 可 以 判断 是 否 发 生 过 SQL 注入 漏洞 攻击 事件 ; 另外 ,还 可 以 
通过 查看 数据 库 审计 日 志 , 查 询 某 个 时 间 段 是 否 有 非法 的 插入 修改、 删除 操作 。 

(5) 其 他 

SQL 注入 漏洞 攻击 成 功 后 ,入侵 者 往往 会 添加 特权 用 户 ( 如 administrator、 root、sa 等 )、 
开放 非法 的 远程 服务 以 及 安装 木马 后 门 程序 等 ,可 以 通过 查看 用 户 账户 列表 、 远 程 服务 开启 
情况 .系统 最 近日 期 产生 的 一 些 文件 等 信息 来 判断 是 否 发 生 过 入 侵 。 


9.2.4 SQL 注入 攻击 的 防范 


(1) 数据 有 效 性 校 验 。 确 保 应 用 程序 要 检查 以 下 字符 : 分 号 .等 号 、 破 折 号 、 括 号 以 及 
SQL 关键 字 。 另 外 ,限制 表单 数据 输入 和 查询 字符 串 输入 的 长 度 也 是 一 个 好 方法 。 

(2) 封装 数据 信息 。 对 客户 端 提交 的 数据 进行 封装 ,不 要 将 数据 直接 存 入 Cookie 中 。 

(3) 去 除 代 码 中 的 敏感 信息 。 将 在 代码 中 存在 的 用 户 名 口令 信息 等 敏感 字段 删除 , 蔡 
换 成 输入 框 。 

(4) 替换 或 删除 单 引号 。 使 用 双 引 号 蔡 换 所 有 用 户 输入 的 单 引 号 ,这 个 简单 的 预防 措 
施 将 在 很 大 程度 上 预防 SQL 注入 漏洞 攻击 。 

(5) 指定 错误 返回 页 面 。 

(6) 限制 SQL 字符 串 连接 的 配置 文件 。 

(7) 设置 Web 目录 的 访问 权限 。 将 虚拟 站 点 的 文件 目录 禁止 游客 用 户 访问 。 

(8) 最 小 服务 原则 。Web 服务 器 应 以 最 小 权限 进行 配置 ,只 提供 Web 服务 ,这 样 可 以 
有 效 地 阻止 系统 的 危险 命令 ,如 ftp、cmd 、vbscript 等 。 

(9) 鉴别 信息 加 密 存 储 。 将 数据 库 users 表 中 的 用 户 名 ,口令 信息 以 密 文 形式 保存 。 

(10) 用 户 权限 分 离 。 应 尽 可 能 禁止 或 删除 数据 库 中 sa 权限 用 户 的 访问 ,对 不 同 的 数 





据 库 划分 不 同 的 用 户 权限 。 


9.3 ” 跨 站 脚本 攻击 














9.3.1 跨 站 脚本 攻击 概述 


跨 站 脚本 攻击 (Cross Site Scripting, 为 区 别 于 CSS, 简 称 XSS) 是 指 Web 应 用 程序 在 将 
数据 输出 到 网 页 时 存在 问题 ,导致 攻击 者 可 以 将 构造 的 ; pp net 因为 
跨 站 脚本 攻击 都 是 向 网 页 内 容 中 写 和 一段 恶意 的 脚本 或 者 HTML 代码 , 故 跨 站 脚本 攻击 
也 被 叫 作 HTML 注入 漏洞 CHTML Injection) 。 

与 SQL 注入 攻击 数据 库 服务 器 的 方式 不 同 , 跨 站 脚本 攻击 是 在 客户 端 发 动 攻击 的 ,也 
就 是 说 ,利用 跨 站 脚本 漏洞 注入 的 恶意 代码 是 在 用 户 计算 机 上 的 浏览 器 中 运行 的 。 

跨 站 脚本 攻击 是 一 种 迫使 Web 站 点 回 显 可 执行 代码 的 攻击 技术 ,而 这 些 可 执行 代码 是 
由 攻击 者 产生 的 ,最 终 会 被 用 户 浏览 器 加 载 。 大 多 数 攻击 一 般 只 涉及 攻击 者 和 受害 者 ,而 
XSS 涉及 三 方 , 即 攻击 者 ,被 攻击 者 利用 的 网 站 、 受 害 者 客户 端 。XSS 攻击 的 原理 如 图 9-2 




































所 示 。 
加 回 攻 击 者 通过 表单 提交 
恶意 代码 给 服务 器 
加 服务 器 保存 
pe Cs 了 恶意 代码 
oggae 
信息 
下 的 网 服务 器。 起 代 古 天 天 所 让 
@@ 目标 用 户 访问 含有 
恶意 代码 的 网 页 
目标 用 户 
图 9-2 XSS 攻击 的 原理 
XSS 攻击 的 分 类 如 下 。 


(1) 持久 型 跨 站 : 最 直接 的 危害 类 型 , 跨 站 代码 存储 在 服务 器 (数据 库 ) 。 

(2) 非 持久 型 跨 站 : 反射 型 跨 站 脚本 漏洞 是 最 普遍 的 类 型 。 用 户 访问 服务 器 一 跨 站 链 
接 一 返回 跨 站 代码 。 

(3) DOM 跨 站 (DOM XSS) :DOM(Document Object Model ,文档 对 象 模型 ) ,客户 端 脚 
本 处 理 逻 辑 导致 的 安全 问题 。 


9.3.2 跨 站 脚本 攻击 的 实例 


1. 一 个 实例 演示 
一 个 跨 站 脚本 攻击 的 实例 如 图 9-3 所 示 。 
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9-3 ”路 站 脚本 攻击 的 实例 




















2. 防范 XSS 攻击 的 方法 
在 PHP 中 ,一 般 利 用 htmlspecialchars 或 htmlentities 函数 将 特殊 字符 转换 成 HTML 
字符 实体 。 


<?php 

$ title= htmlspecialchars( $ _POST[ 'Title']); 

$ content = htmlspecialchars( $ _POST[ 'content ']); 
?> 


3. 利用 XSS 任意 删除 留言 
攻击 者 可 以 发 表 一 条 留言 ,留言 的 内 容 如 下 : 
< img src = "delbook. php? id= 2" /> 
则 管理 员 用 账号 登录 后 ,只 要 一 查看 留言 ,就 会 自动 将 ID 号 为 2 的 留言 删除 。 
9.3.3 防范 跨 站 脚本 攻击 的 方法 


(1) 不 要 在 允许 位 置 插入 不 可 信 数 据 。 

(2) 在 向 HTML 元 素 内 容 插 人 不 可 信 数 据 前 对 HTML 解码 。 

(3) 在 向 HTML 常见 属性 插入 不 可 信 数 据 前 进行 属性 解码 。 

(4) 在 向 HTML JavaScript Data Values 插入 不 可 信 数 据 前 ,进行 JavaScript 解码 。 
(5) 在 向 HTML 样式 属性 值 插入 不 可 信 数 据 前 ,进行 CSS 解码 。 

(6) 在 向 HTML URL 属性 插入 不 可 信 数 据 前 ,进行 URL 解码 。 


9.4 身份 认证 系统 的 制作 

身份 认证 就 是 通过 特定 手段 对 用 户 所 声称 的 身份 进行 认证 的 过 程 , 它 是 实现 网 络 安全 
的 重要 机 制 。 

9.4.1 PHP 的 加 密 函 数 


为 了 用 户 的 数据 安全 ,经 常会 对 数据 进行 加 密 。 对 一 些 比较 常用 的 加 密 算 法 ,PHP 提 
供 了 非常 有 力 的 支持 , 像 crypt、md5 和 shal, 都 可 以 直接 调用 。 

1. crypt 函数 

crypt 函数 对 字符 串 加 密 有 两 种 方式 ,例如 : 


$ ciph= crypt("hello" ); 
$ ciph2 = crypt("hello", "php"); ”// 前 一 个 参数 是 要 加 密 的 字符 串 ,后 一 个 为 密 钥 
2. md5 函数 
php 
$ str= "hello"; 
Echo md5( $ str); 
?> 
3. shal 函数 
shal 函数 与 md5 函数 类 似 ,与 md5 不 同 的 是 shal 默认 返回 40 个 字符 的 散 列 值 。 


<?php 
$ str= "hello"; 
echo shal( $ str); 
?> 


三 个 加 密 函数 都 是 单 向 加 密 , 没 有 逆向 解密 算法 。 
9.4.2 用 户 注册 模块 的 实现 


【 例 9-1】 制作 一 个 登录 系统 ,实现 用 户 注 册 功 能 。 假 设 数据 库 为 STU ,数据 库 中 有 一 
个 表 user, 表 的 结构 如 表 9-2 所 示 。 
表 9-2 user 表 的 结构 



































项 目 名 列 名 数据 类 型 长 度 是 否 可 空 | 默认 值 说 明 
主键 , 由 英文 字 
用 户 名 | username | 不 定 长 字符 型 (varchar) 20 pb lr 母 .下 夯 线 或 数 
字 组 成 
密码 password | 不 定 长 字符 型 (varchar) 20 x 无 6 一 20 位 字符 
性 别 sex 位 型 (bit) 默认 值 x 1 1; 男 ; 0: 女 
年 龄 age 整数 型 Cint) 默认 值 V. 无 
邮箱 email 定 长 字符 型 (char) 30 Vv 无 
<html> 
<head> 
<title > 用 户 注册 页 面 </title> 
</head> 
<body> 
< form action = "" method= "post"> 


< div align = "center">< font size= "5" color ="blue"> 新 用 户 注 册 </font ></div> 
<table width= "340" align = "center”border = "0"> 
KE 
<td width= "80" align = "right"> 用 户 名 :</td> 
<td>< input type= "text" name = "userid"></td> 
<td>< font color = "red">* 1 一 20 个 字符 </font ></td> 
</tr> 
引 = 才 
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<tdalign= "right"> 密 码 : </td> 
<td>< input type = "password" name= "pwdl"” size= "21"></td> 
<td>< font color = "red">* 6 一 20 个 字符 </font ></td> 

</tr> 

<tr> 
<tdalign= "right"> 确 认 密 码 : </td> 
<td>< input type = "password" name= "pwd2" size= "21"></td> 
<td> gnbsp;</td> 


</tr> 
<tr> 
<tdalign= "right"> 性 别 : </td> 
<td> 
< input type = "radio" name = "sex" value = "1"> 男 
< input type = "radio" name = "sex" value= "0"> 女 
</td> 
<td> gnbsp;</td> 
</tr> 
<tr> 


<tdalign= "right"> 年 龄 : </td> 
<td>< input type = "text" name = "age"></td> 
<td> gnbsp;</td> 
</tr> 
<tr> 
<tdalign= "right">email: </td> 
<td>< input type = "text" name = "email"></td> 
<td> gnbsp;</td> 
</tr> 
<tr> 
<tdcolspan= "3" align= "center"> 
< input type = "submit" name = "Submit"” value = "提交 "> 
< input type = "reset" name = "Submit2" value = " 重 置 "> 
</td> 
</tr> 
</table> 
</form> 
</body> 
</html > 
<?php 
if(isset( $ _POST[ 'Submit7])) 
{ 
$ userid= $ _POST[ 'userid']; 
$ pwdl = $ _POST[ 'pwd1 ']; 
$ pwd2 = $ _POST[ 'pwd2 ']; 
$ sex= @ $ _POST[ 'sex']; 
$ age= $ _POST[ 'age']; 
$ email = $ _POST[ ‘email ']; 
$ checkid = preg_match( '/^\w{1,20} $/', $ userid); 
$ checkpwdl = preg_match( '/*\w{6,20} $ /', $ pwd1); 
checkemail = preg_match( '/^[a—-zA—-20-9_\-]+@[a-zA—-20-9\-]+\.[a-zA-20— 
9\-\.]+$/',$email); 
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if(! $ checkid) 
echo "< script >alert( ' 用 户 名 设置 错误 ! ');</script >"; 
elseif(! $ checkpwdl ) 
echo "< script >alert( ' 密 码 设置 错误 ! ') ;</script >"; 
elseif(! $ sex) 
echo "< script >alert( ' 性 别 为 必 选 项 ! ') ;</script >"; 
elseif( $ age&g&(!is_numeric( $ age))) 
echo "< script>alert( ' 年 龄 必须 为 一 个 数字 ! ') ;</script>"; 
elseif( $ email&&(! $ checkemail)) 
echo "< script >alert( 'email 格式 错误 ! ');</script >"; 
elseif( $ pwdl!= $ pwd2) 
echo "< script >alert( ' 两 次 输入 的 密码 不 一 致 ! ');</script >"; 
else 
{ 
include "sqlcon. php"; // 连 接 数 据 库 
$s_sql = "select * from user where username = '$ userid"; 
$ s_result = $db—>query( $ s_sql); 
if( $s_result— > rowCount()!=0) 
echo "< script >alert( ' 用 户 名 已 存在 ! ');</script >"; 
else 
{ 
$ in_sql = "insert into user( username, password, sex, age, email) values(?,?,?,?,?)"; 
$ in_result = $ db—>prepare( $ in_sql); 
$ in_result ->bindParam(1, $ userid); 
$ in_result ->bindParam(2, $ pwd1); 
$ in_result ->bindParam(3, $ sex); 
$ in_result ->bindParam(4, $ age); 
$ in_result ->bindParam(5, $ email); 
$ in_result - > execute( ); 
if( $ in_result 一 > rowCount() == 0) 
echo "< script >alert( ' 注 册 失 败 ! ');</script >"; 
else 
{ 
echo "< script>alert( ' 注 册 成 功 ! ');1ocation.href = 's19_2. php';</script >"; 


9.4.3 用 户 登录 模块 的 实现 
【 例 9-2】 制作 一 个 登录 系统 ,实现 用 户 登录 功能 。 


< htm] > 
<head> 
<title> 用 户 登录 页 面 </title> 
</head > 
<body> 
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< form action = "" method= "post"> 
< div align = "center">< font size = "5"” color = "blue"> 用 户 登 录 </font ></div> 
<table align = "center"> 
<tr> 
< td> 用 户 名 :</td> 
<td>< input type = "text" name = "userid"></td> 
</tr> 
<tr> 
< td> 密 码 : </td> 
<td>< input type = "password" name = "pwd" size ="21"></td> 





</tr> 
二 = 本 
<td colspan = "2" align = "center"> 
< input type = "submit" name = "Submit"” value = "登录 "> 
< input type = "reset" name = "Submit2" value = "注册 ”onclick = "window. location = 
'EX10_1_regist. php "> 
</td> 
</tr> 
</table> 
</form> 
</body> 
</html > 
<?php 


include "sqlcon. php"; 
if(isset( $ _POST[ ‘Submit '])) 
{ 


$ userid= $ _POST[ 'userid']; // 用 户 名 
$ pwd= $ _POST[ 'pwd']; // 密 码 
$ sql = "select * from user where username = '$ userid'"; 
$result = $ db—>query( $ sql); // 查 看 用 户 名 是 否 存 在 
if(list( $ username, $ password, $ sex, $ age, $ email) = $ result — > fetch(PDO: :FETCH_NUM)) 
{ 
if( $ password == $ pwd) // 判 断 密码 是 否 正确 
| 
session_start(); 
$ _SESSION[ 'userid'] = $ userid; // 使 用 SESSION 传 值 
header( "location:main. php"); // 进 入 主页 
} 
else 
echo "< script >alert( ' 密 码 错 误 ! ');</script >"; 
} 
else 
echo "< script >alert( ' 用 户 名 不 存在 ! ');</script >"; 
} 
?> 


9.5 项 目 实 训 一 一 修改 密码 模块 的 实现 


实 训 目的 


(1) 了 解数 据 库 连 接 的 步 又。 
(2) 掌握 一 般 加 密 算法 的 使 用 。 














实 训 要 求 
在 例 9-1 和 例 9-2 的 基础 上 完成 如 图 9-4 所 示 的 用 户 密码 的 修改 功能 。 
密码 修改 
原 密码 : . 
新 密码 ， | *eeeeeee 
男 
图 9-4 ”用 户 密码 的 修改 
思考 与 练习 
一 、 选 择 题 
1. 如 果 要 在 字符 串 中 过 滤 关 键 字 and, 可 以 使 用 以 下 ( ) 函 数 。 
A. crypt B. addslashes C. str_replace D. htmlentities 
2. XSS 攻击 注入 的 目标 不 可 以 是 ( ; 
A. HTML B. JavaScript ©. PHP D. XML 
3. 下 列 ( ) 函数 加 密 的 信息 是 可 以 被 还 原 的 。 
A. crypt B. md5 C. shal D. urlencode 
二 、 简 答题 


1. 为 了 将 一 个 变量 强制 转换 为 整 型 ,需要 使 用 哪个 函数 ? 
2. 简 述 SQL 注入 攻击 与 XSS 攻击 的 区 别 。 
3. htmlentities 与 htmlspecialchars 两 个 函数 的 功能 是 什么 ?它们 有 何 区 别 ? 
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$e 


学 生 学 籍 成 绩 管理 系统 开发 实例 


本 章 通 过 对 学 生 学 籍 成 绩 管理 系统 开发 主要 过 程 的 讲解 ,让 学 生 对 开发 软件 的 流程 有 
一 个 清晰 的 认识 ,进而 更 好 地 掌握 前 面 章节 所 学 的 内 容 ,本 系统 采用 PHP 十 MySQL 开发 
而 成 。 


10.1 系统 需求 分 析 


目前 ,我 国 大 中 专 学 校 的 学 生 学 籍 、 成 绩 管理 水 平 普遍 不 高 ,有 的 其 至 停留 在 纸 介 质 状 
态 。 这 种 管理 手段 浪费 了 大 量 的 人 力 和 物力 ,已 不 能 适应 当今 信息 时 代 的 发 展 。 现 开发 一 
个 信息 系统 ,用 来 统计 和 管理 二 级 学 院 ( 学 系 ) 在 读 学 生 的 学 籍 、 成 绩 , 帮 助教 务 部 门 和 广大 
教师 提高 工作 效率 ,实现 学 生 学 籍 成绩 管理 工作 的 系统 化 ` 规 范 化 和 自动 化 。 

本 系统 设置 3 种 用 户 类 型 。 中 系统 管理 员 : 由 二 级 学 院 ( 学 系 ) 教 学 秘书 担任 ,可 实现 
教师 用 户 ,班级 信息 、 学 生 用 户 、 课 程 设置 信息 、 开 课表 的 查 、 增 、 删 、 改 和 学 生成 绩 统计 。 
@ 任 课 教师 : 可 查询 自己 任教 班级 的 学 生 学 籍 ; 可 对 自己 任教 课程 各 学 生 的 成 绩 进行 查 、 
增删 \ 改 ; 可 修改 自己 的 密码 。@ 学 生 : 可 查询 自己 各 课程 的 成 绩 ; 可 修改 自己 的 密码 。 
不 同 用 户 登录 后 看 到 的 界面 是 不 同 的 。 为 此 ,将 整个 系统 划分 为 3 个 子 系统 : 系统 管理 员 
子 系统 、 任 课 教师 子 系统 和 学 生子 系统 ,每 个 子 系统 又 划分 为 若干 功能 模块 。 

1. 系统 管理 员 子 系统 

(1) 教师 管理 : 对 教师 信息 进行 查 、 增 、 删 、 改 。 

(2) 班级 管理 : 对 班级 信息 进行 查 、 增 、 删 、 改 。 

(3) 学 生 学 籍 管理 : 对 各 班 学 生 的 学 籍 进行 查 、 增 、 删 \ 改 。 

(4) 课程 设置 管理 : 对 各 专业 的 课程 设置 表 进行 查 、 增 、 删 \ 改 。 

(5) 开课 表 管 理 : 对 各 班级 各 学 期 的 开课 表 进行 查 、 增 、 删 改 。 

(6) 学 生成 绩 统 计 : 当 任 课 教师 录入 学 生 各 课程 成 绩 后 ,系统 管理 员 就 可 查询 各 班 各 
位 学 生 的 全 部 课程 成 绩 , 统 计 各 位 学 生 的 总 分 和 平均 分 ,并 按照 总 分 进行 班级 排名 。 
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2. 任课 教师 子 系统 


发 案例 教程 


(1) 学 生 学 籍 查询 : 查询 任教 各 班级 学 生 的 学 籍 。 
(2) 学 生成 绩 管理 : 用 于 查 、 增 、 删 、 改 任教 班级 任教 课程 各 学 生 的 成 绩 。 
(3) 密码 修改 : 修改 自己 的 登录 密码 。 


3. 学 生子 系统 


(1) 成 绩 查询 : 按 学 期 查询 自己 各 门 课程 的 成 绩 , 并 显示 总 分 和 平均 分 。 
(2) 密码 修改 : 修改 自己 的 登录 密码 。 


10.2 数据 库 设计 


本 系统 中 涉及 的 主要 业务 数据 有 3 种 用 户 的 信息 、 班 级 信息 .课程 设置 信息 、 开 课表 信 
息 、 学 生成 绩 及 功能 菜单 等 ,相关 数据 表 结构 详 见 表 10-1 至 表 10-8。 

































































表 10-1 管理 员 表 (admin) 

字 段 类 型 (长 度 ) 空 默认 描述 
adminid varchar(12) 否 无 用 户 名 ,主键 
pwd varchar(12) 否 无 密码 

表 10-2 教师 表 (teacher) 

字 有 段 类 型 (长 度 ) 空 默认 描述 
teacherid varchar(10) 否 无 教工 号 ,主键 
teachername varchar(12) 否 无 姓名 
pwd varchar(12) 否 无 密码 
level varchar(8) 否 无 职称 
tel varchar(12) 是 无 联系 电话 

表 10-3 学 生 表 (student) 

字 段 类 型 (长 度 ) 空 默认 描 述 
studentid varchar(10) 否 无 学 号 ,主键 
studentname varchar(12) 否 无 姓名 
pwd varchar(12) 否 无 密码 
sex varchar(2) 是 无 填 : 男 , 女 
birthday date 是 无 出 生日 期 
classid varchar(6) 否 无 班级 序号 
credit int(4) 是 0 总 学 分 

表 10-4 班级 表 (class) 
字 有 自 类 型 (长 度 ) 空 默认 描述 
aid ay 天 和 班级 序号 ,主键 ,由 2 位 入 学 年 
人 份 十 2 位 专业 号 十 2 位 班 号 组 成 























续 表 


































































































字 段 类 型 (长 度 ) 空 默认 描 述 

enrollyear int(4) 否 2016 入 学 年 份 

majorname varchar(10) 否 无 专业 名 称 

classname varchar(4) 否 无 班 名 ,如 1 班 

num int(4) 是 0 班 人 数 

表 10-5 课程 表 (course) 
字 段 类 型 (长 度 ) 空 默认 描 述 
课程 号 ,主键 ,公共 课程 的 课程 号 
courseid varchar(8) 否 无 唯一 ,但 同一 专业 课程 在 不 同 专 
业 开设 ,具有 不 同 的 课程 号 
coursename varchar(20) 否 无 课程 名 
period int(4) 否 无 总 课时 
credit int(4) 否 1 学 分 
majorname varchar(10) 否 ; 专业 名 称 、 公 共 课 
表 10-6 开课 表 (offercourse) 

学 段 类 型 (长 度 ) 空 默认 描 述 
classid varchar(6) 否 无 班级 序号 ,主键 
courseid varchar(8) 否 无 课程 号 ,主键 
weekhour int(4) 否 无 周 课时 
weeknum decimal(4.1) 否 无 周 数 
offerterm varchar(12) 否 无 开课 学 期 ,格式 形 如 2016-2017(2) 
teacherid varchar(10) 是 无 教工 号 

表 10-7 成 绩 表 (score) 

学 段 类 型 (长 度 ) 空 默认 描 述 

studentid varchar(10) 否 无 学 生 学 号 ,主键 

courseid varchar(8) 否 无 课程 号 ,主键 

score int(4) 是 0 成 绩 

offerterm varchar(12) 否 无 开课 学 期 ,格式 形 如 2016-2017(2) 

表 10-8 功能 菜单 表 (menu) 

字 段 类 型 (长 度 ) 空 默认 描 述 

id int(4) 否 无 序号 ,主键 

menuname varchar(10) 否 无 菜单 名 

url varchar(20) 是 无 转向 页 面 

role varchar(10) 是 无 用 户 类 型 





10.3 系统 配置 和 数据 库 连接 


和 


系统 配置 


在 PC 中 安装 如 下 开发 环境 : 四 安装 并 配置 集成 开发 环境 WampServer; 四 安装 PHP 
编辑 器 Dreamweaver CS4; @ 安 装 数据 库 管理 工具 Navicat_Premium, 在 Navicat_Premium 
中 创建 数据 库 stu_db, 在 其 中 创建 10. 2 节 中 设计 的 8 个 数据 表 。 


2 


文件 架构 


使 用 Dreamweaver CS4 创建 站 点 stu_project ,在 站 点 中 创建 网 页 ,系统 主要 页 面 如 
图 10-1 所 示 。 





系统 登录 页 面 
Login.php 





教师 管理 Teacher.php 
班级 管理 Class.php 
学 生 学 籍 管理 Student.php 
课程 设置 管理 Course.php 
开课 表 管 理 Offercourse.php 
学 生成 绩 统计 Countscore.php 
密码 修改 Changepwd.php 
个 人 信息 查询 Index.php 
学 生 学 籍 查询 Student.php 
学 生成 绩 管理 Score.php 


















































































密码 修改 Changepwd.php 
个 人 信息 查询 Index.php 
成 绩 查 询 Score.php 



























密码 修改 Changepwd.php 
图 10-1 系统 主要 文件 架构 图 
3. 数据 库 连 接 
本 系统 将 数据 库 连 接 代码 存储 在 Fun. php 文件 中 ,其 他 页 面 如 需 使 用 数据 库 都 要 调用 
本 文件 ,代码 如 下 : 
<?php 
// 连 接 数据 库 
error_reporting(E_ALL ^ E_DEPRECATED) ; // 错 误 控 制 
header( "Content - type:text/html;charset = utf 一 8"); // 客 户 端 发 送 原始 的 HTTP 报头 
$ conn = mysql_connect( ‘localhost ', 'root', ''); // 连 接 MySQL 服务 器 
mysql_select_db( 'stu_db', $ conn); // 选 择 数 据 库 
mysql_query( "SET NAMES utf8"); // 设 置 字符 集 为 utf8 
session_start(); // 启 动 session 会 话 


有 























4. 系统 登录 页 面 
系统 入 口 页 面 是 登录 页 面 Login. php ,运行 界面 如 图 10-2 所 示 。 








用 户 名 : ”| 学 /I 号 














宣 码 : 密码 
加 管理 员 〇 任课 教师 O 学 生 


有 Ea 


10-2 登录 页 面 











相关 代码 如 下 : 


<head> 
<meta http— equiv = "Content - Type" content = "text/html; charset = utf - 8" /> 
<title> 学 生 学 籍 成 绩 管理 系统 </title> 
</head> 
< Script language = "JavaScript"> 
if(window. top. location. href!= window. location. href) 
{ 
window. top. location. href = window. location. href; 
</script > 
<body> 
< form action method = "post"> 
<table width= "35%" border = "1" align = "center" cellspacing = "0" bordercolor = " #328EBE"> 
<tr> 
<td align = "center" valign = "middle” bgcolor = " 间 328EBE">< h2 > 学 生 学 籍 成 绩 管理 系统 
</h2 ></td> 
</tr> 
过 镀 闫 
<td height = "133"> 
<table width= "328" border = "0" align = "center"> 
“Ee 
<td width= "98" height ="30" align = "center"> 用 户 名 : </td> 
<td width = "230" height = "30">< input name = "userid" type = "text" size ="26" 
placeholder = "学 号 / 工 号 "/></td> 
</tr> 
<tr> 
< td height 0" align = "center"> 密 码 : </td> 
<td height = "30">< input name = "password" type = "password" size = "26"”placeholder = 
"密码 "/></td> 
</tr> 
<tr> 
<td height = "30" colspan = "2" align = "center"> 
< input name = "role" type = "radio" value = "admin" checked = "checked" /> 管理 员 
< input type = "radio" name = "role" value = "teacher" /> 任课 教师 









< input type= "radio" name = "role" value = "student" /> 学 生 
</td> 
</tr> 
</tr> 
<td height = "30" colspan = "2" align = "center">< input type = "submit" name = 
value = " 登 录 " /></td> 
</tr> 
</table> 
</td> 
</tr> 
</table> 
</form> 
<?php 
session_start(); // 启 动 会 话 
session_destroy(); // 删 除 会 话 所 占 空 间 
include "Fun. php"; // 调 用 Fun. php 文件 
if(isset( $ _POST["login"])) 
{ 


$ role= $ _POST[ "role"]; // 获 取 用 户 类 别 
$ userid= trim( $ _POST[ "userid" ]); // 获 取 用 户 名 
$ pwd = trim( $ _POST["password" ]); // 密 码 


"login" 


$sql= "select * from $ role where ". $ role."id= '$ userid'and pwd= '$ pwd'"; 


$ result = mysql_query( $ sql); 
$ row= mysql_fetch_array( $ result); 
if( $ row) 
{ // 登 录 成 功 则 把 用 户 类 别 及 用 户 名 写 人 SESSION 
$ _SESSION[ "role"] = $ role; 
$ _SESSION[ "userid"] = $ userid; 
echo "< script > location. href = 'Index. php';</script >"; 
} 
else 


| 


echo "< script>alert( ' 用 户 名 或 密码 错 ! '); location. href = 'login. php';</script >"; 


} 
} 


?> 
</body > 


5. 用 户 权限 主页 


用 户 登录 后 进入 用 户 权 限 主 页 Index. php,Index php 是 一 个 框架 集 文件 ,包含 4 个 框架 ， 














框架 top 用 于 显示 Top. php 网 页 ,框架 menu 用 于 显示 Menu. php 网 页 ,框架 foot 
示 Foot. php 网 页 ,框架 main 用 于 显示 各 子 系统 ( 子 目录 ) 下 的 文件 。 其 代码 如 下 : 


<html> 

<head> 

<meta http— equiv = "Content - Type" content = "text/html; charset = utf — 8"> 
<title> 学 生 学 籍 成 绩 管理 系统 </title> 

</head> 

<?php include "IsLogin. php"; // 判 断 用 户 是 否 登 录 




















于 显 





<frameset rows = "106, * ,26" cols ="*" frameborder = "no" border = "0" framespacing = "0"> 
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< frame name = "top" scrolling= "no" noresize src= "Top.php" > 





< frameset rows ="* "cols = "190, * " framespacing = "0" frameborder = 
"myFrame"> 
<frame name = "menu" noresize scrolling = "auto" src = "Menu. php"> 
<frame name = "main" scrolling = "auto" src = "<?php echo @ $ _SESSION[ 'role']. '/Index. 
php';?>" > 
</frameset > 
< frame name = "foot" noresize scrolling = "no" src = "Foot. php"> 
</frameset > 
<noframes> 
<body> 
</body > 
</noframes > 
</html > 


(1) Top. php 文件 : 为 页 面 项 部 ,同时 显示 当前 登录 用 户 的 信息 ,主要 代码 如 下 : 


<body> 
<div class = "header"> 
< label class = "logo title"> 学 生 学 籍 成 绩 管理 系统 </label > 
</div> 
<div class = "nav"> 
<?php 
session_start( ); 
$ role= "管理 员 "; 
if( $ _SESSION[ "role" ] == "teacher") $ role= "教师 "; 
if( $ _SESSION[ "role"] == "student") $ role= "学 生 "; 
echo "当前 用 户 类 别 : ". $ role.", 用 户 名 : ". $ _SESSION[ "userid"]; 
?> 
</div> 
</body > 


(2) Menu. php 文件 : 为 功能 菜单 页 ,本 系统 把 功能 菜单 存放 在 数据 库 中 ,不 同 的 登录 
用 户 显示 不 同 的 菜单 ,根据 图 10-1 为 功能 菜单 表 (menu) 输 入 记录 ,如 表 10-9 所 示 。 


表 10-9 功能 菜单 表 (menu) 的 内 容 


















































id menuname url role 

1 教师 管理 Teacher. php admin 
2 班级 管理 Class. php admin 
3 学 生 学 籍 管理 Student php admin 
4 课程 设置 管理 Course. php admin 
5 开课 表 管 理 Offercourse. php admin 
6 学 生成 绩 统计 Countscore. php admin 
7 密码 修改 ../Changepwd. php admin 
8 退出 ../LoginOut. php admin 
9 个 人 信息 查询 Index. php teacher 
10 学 生 学 籍 查询 Student. php teacher 
11 学 生成 绩 管理 Score. php teacher 
12 密码 修改 ../Changepwd. php teacher 
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续 表 
id menuname url role 
13 退出 ../LoginOut php teacher 
14 个 人 信息 查询 Index. php student 
15 成 绩 查询 Score. php student 
16 密码 修改 ../Changepwd. php student 
ul 退出 ../LoginOut php student 
主要 代码 如 下 : 
<body> 


<div class = "menu"> 
<div class = "accordion - group"> 
<div class = "accordion 一 title"> 
< img class = "menu ~ icon" src = "images/settings. png" />< span class = "menu 一 
title"> 管 理 菜单 </span > 
</div> 
<?php 
include "Fun. php"; 
if(isset( $_SESSION[ "role" ]) ) 
{ 
$sql = "select * from menu where role= '". $ _SESSION["role"]."'"; 
$ result = mysql_query( $ sql); 
$ row = mysql_fetch_array( $ result); 
//$ row 为 数组 名 , 键 名 可 以 是 整数 和 字段 名 
while( $ row) 
{ 
?> 

<div class = "accordion— inner"> 

< img class = "menu - icon - child" src = " images/menu - icon - child. png" /> < span 

class = "menu - body"> < a href = "<?php echo @ $ _SESSION[ "role"] ?>/<?php echo @ $ row 

"url"] ?>" target = "main"><?php echo @ $ row[ "menuname" ] ?> </a></span> 
</div> 
<?php 
$ row = mysql_fetch array( $ result); 


mysql_free_result( $ result); 
mysql_close( $ conn); 


?> 
</div> 
</div> 
</body> 


(3) Foot. php 文件 : 为 页 面 底部 ,显示 版 权 信 息 ,主要 代码 如 下 : 


< link href ="styles/Index. css" rel = "stylesheet”/> 
<div class = "nav"> 技 术 支持 : 计算 机 系 </div> 
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(4) IsLogin. php 文件 : 判断 用 户 是 否 登录 ,在 子 系统 的 各 个 网 页 中 调用 ,主要 代码 
如 下 : 


<?php 
if(!isset( $ _SESSION["role"])) // 判 断 用 户 是 否 登 录 , 否则 转 用 户 登录 页 面 
{ 
echo "< script >alert( ' 你 还 没有 登录 ! ') ;location. href = '/stu_project/login. php';</script >"; 
} 
?> 


(5) LoginOut. php 文件: 为 3 类 用 户 的 退出 页 面 ,相关 代码 如 下 : 


<meta http — equiv = "Content - Type" content = "text/html; charset =utf - 8" /> 
< script language = "javascript"> 

x= window. confirm(" 您 确定 要 退出 吗 ?"); 

if(x== true) window. top. location. href = "Login. php"; 
</script > 


(6) Changepwd. php 文件 : 为 3 类 用 户 的 密码 修改 页 面 ,主要 代码 如 下 : 


<head> 
<meta http— equiv = "Content - Type" content = "text/html; charset =utf -8" /> 
< script src = "scripts/Com. js"></script > 


<title> 无 标题 文档 </title> 
</head> 
<body> 
< center >< font style= "font - family: ' 华 文 新 魏 '; font - size:20px" > 密码 修改 </font ></center > 
<?php 
include "Fun. php"; // 调 用 Fun. php 文 件 
if(isset( $ _POST["update"])) // 判 断 是 否 单 击 * 修 改 " 按 钮 
{ 
$ test= 1; // 只 要 $ test = 0, 则 表单 信息 就 无 法 提交 
$ role= $_SESSION[ "role"]; // 获 取 用 户 类 别 
$ userid= $ _SESSION[ "userid"]; // 获 取 用 户 名 
$ pwd = $ _POST[ "password" ]; // 获 取 原 密码 
$ newpwd = $ _POST[ "password1" ]; // 获 取 新 密码 
$ confirm= $ _POST[ "password2" ]; // 获 取 确 认 密 码 


// 车 正则 表达 式 含 ^、$ ,只 有 正则 表达 式 与 字符 串 完全 匹配 ,该 函数 才 返 回 1 
if( $ pwd =="") {$ pwdl = "必须 输入 原 密码 !1"; $ test = 0;} 
else 
{$sql= "select * from". $ role." where ". $ role."id= '". $userid."'and pwd = 
'$ pwd'"; 
$ result = mysql_query( $ sql); 
if (mysql_num rows( $ result) == 0) 
{$ pwdl = "输入 的 原 密码 不 存在 ,请 重 输 !"; $ test = 0;} 
} 
if( $ newpwd =="") { $ newpwdl = "必须 输入 新 密码 !"; $ test = 0;} 
if (strcmp( $ newpwd, $ confirm)!= 0) {$confirml = "确认 密码 必须 与 新 密码 相同 !"; 
$ test= 0;} 
if ($ test==1) 
{ 
$sql="update ". $ role." set pwd= '$ newpwd'where ". $ role."id= ". $ userid." "; 





mysql_query( $ sql); 
echo "< script language = 'javascript '> alert( ' 修 改 成 功 ! ') ;</script >"; 


?> 
< form name = "forml" method= "post" action = ""> 
< table width= "500" border = "1" align= "center" cellspacing = "0" bordercolor = " #328EBE"> 








<tr> 
<tdwidth= "150"” height = "30" align = "center"> 原 密码 </td> 
<td width= "350" height = "30">< input type = "password" name = "password" value = 


"<?php echo @ $ pwd; ?>"/><?php echo "< font size = '2' color = 'FF0000'>".@ $ pwdl. 
"</font >";?></td> 
</tr> 
<tr> 
<td width= "150" height = "30" align = "center"> 新 密码 </td> 
<td width= "350" height = "30">< input type = "password" name = "password1l" value = 
"<?php echo @ $ newpwd; ?>"/><?php echo "<font size= ‘2 ' color = 'FF0000 '>". @ 
$ newpwd1. "</font >" ;?></td> 
</tr> 
<td width= "150"” height = "30" align = "center"> 确 认 密 码 </td> 
<td width= "350" height = "30">< input type = "password" name = "password2" value = 
"<?php echo @ $ confirm; ?>"/><?php echo "< font size = '2' color = 'FF0000'>".@ 
$ confirm1. "</font >";?></td> 
</tr> 
<tr> 
<td height = "30" colspan= "2" align = "center"> 
< input type = "submit" name = "update" value=" 修 改 " /> 
</td> 
</tr> 
</table> 
</form> 
</body > 


(7) Com.js 文件: 为 JavaScript 脚本 页 面 ,存放 于 scripts 文件 夹 中 ,主要 代码 如 下 : 
// 检 查 是 否 选 择 " 全 选 ” 按 钮 


function checkall( form) 
{ 
for (var i=0;i<form.elements. length; i++) 
{ 
var e = form.elements[i]; 
if (e.name != ‘CBox' && e.type== ‘checkbox') 
e. checked = form.CBox.checked; 


} 
// 弹 出 对 话 框 确认 删除 


function delcfm( ) 


if (!confirm(" 确 认 要 删除 ?")) 
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window. event. returnValue = false; 
} 
$ 
// 检 查 两 次 密码 是 否 一 致 
function check( ) 
{ 
if(document. forml. password1. value == "") 
{ ”alert(" 请 输入 新 密码 !"); 
document. form1.password1. focus( ); 
return false; 
} 
if(document. forml. password2. value == "" | 
document. form1. password2. value!= document. form1. passwordl .value) 


{ ”alert(" 两 次 输入 的 密码 不 一 致 !"); 
document. form1. password2. focus( ); 
return false; 


10.4 系统 管理 员 子 系统 的 实现 


当 系 统管 理 员 登录 后 ,用 户 权限 主页 Index. php 的 运行 界面 如 图 10-3 所 示 。 单 击 左边 
的 功能 菜单 ,就 会 在 右边 显示 执行 结果 。 


学 生 学 籍 成 绩 管理 系统 


当前 录用 户 共 别 ; 管理 郧 ,用户 各 : admin Top. php 


与 管理 菜单 管理 员 必 读 

【可 和 理 】 对 由 卫 信 和 进行 查 、 堆 、 狂 、 改 . 

© 教师 管理 【于 坝 管理 】 对 浙 妇 信息 进行 查 、 增 、 测 、 改 . 
【学生 学 精 管 理 】 对 各 镶 学 生 的 学 楼 过 行 查 、 

全 班级 管理 | 【 媒 委 设 雪 管理 】 对 各 专业 的 当 怀 设 罗 表 运 行 至 、 油 、 改 , 

人 @ 半生 学 夭 管 理 5 【开展 管理 】 对 入 起 各 学 天 的 开 当 家 运行 查 、 境 、 抽 区。 


全 课程 设置 管理 
伟 开课 表 管理 
全 学 生成 绩 统计 
她 密码 修改 
时 退出 

Menu. php 


图 10-3 用 户 权限 主页 





























6“【 玫 生 霹 汪 尝 计 】 统计 各 折 帮 位 字 生 名 课程 戌 总 分 、 








10.4.1 教师 管理 


1. Teacher. php 教师 查询 .删除 页 面 
系统 首先 分 页 查询 全 部 教师 的 信息 ; 若 输入 姓名 的 关键 字 , 则 模糊 查询 姓名 中 含有 该 


(174) PHP 动 态 网 站 开发 案例 教程 


关键 字 的 所 有 教师 信息 。 运 行 界面 如 图 10-4 所 示 。 
iM 名 : |] 





















































工 号 姓名 室友 职称 联系 电话 EE 
2000000096 | 。 黄 运 123 讲师 。 | 12345678901 四 
2000000110 | 加 如 123 讲师 口 
2000000202 | 李 先 123 讲师 口 
2010000001 | 印 候 123 副教授 口 
2010000725 | 王 兰 123 讲师 口 
2010000726 | 。 李霞 123 讲师 口 

For | we | 123 | | 

‘20000781 | pe | 1 | ws | 

2013000146 | 。 邵 兵 123 讲师 口 

2013000526 | ” 陈 晓 123 讲师 品 

二 1 2 3 下 -页 共 了 责 国 
wn |] [mW] 




















图 10-4 教师 查询 页 面 


每 一 页 显示 多 条 教师 记录 ,其 中 在 教工 号 中 出 现 超 链 接 , 页 面 的 底部 显示 “添加 “删除 ” 
按钮 。 若 选择 某 些 教师 记录 ,并 单 击 “ 人 删除” 按钮 , 则 删除 选中 的 教师 记录 ; 若 单 击 “ 添 加 ” 按 
钮 ,就 显示 记录 添加 页 面 ; 若 单 击 某 条 记录 的 超 链接 ,就 显示 该 记录 的 修改 页 面 。 

相关 代码 如 下 : 


<head> 
<meta http— equiv = "Content - Type" content = "text/html; charset =utf - 8" /> 
< link href ="../styles/com. css" rel = "stylesheet" /> 
<style type = "text/css"> 
table { 
width: 70%; 
margin: 0 auto; 


, 


</style> 

< script src = "../scripts/Com. js"></script > 
< title > 教师 信息 </title> 

</head> 

<body> 


< form method = "post"> 
<divalign = "center"> 
<font style = "font - family: ' 华 文 新 魏 '; font - size:20px" > 教师 管理 </font >< br > 
请 输入 姓名 : 
< input type = "text" name = "name" /> 
< input name = "search" type = "submit"” value = "查询 "/> 
<table> 
<thead> 
er 
<thwidth="20% "> 工 号 </th> 
<thwidth="15% "> 姓名 </th> 
<th width="15% "> 密码 </th> 
<th width= "15$ "> 职称 </th> 
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<th width = "20 % "> 联系 电话 </th> 
<th width = "15 % "> 删除 < input type = 'checkbox' id = 'CBox' onClick = 'checkall(this. 
form) '/></th> 

</tr> 


</thead> 

<?php 
include "../Fun. php"; 
include "../IsLogin. php"; 
function loadinfo( $ sqlstr) 


{ 


$ result = mysql_query( $ sqlstr); // 查 询 数 据 库 

$ total = mysql_num_rows( $ result); // 获 取 所 查询 记录 的 总 数 
if (isset( $ _REQUEST["search"])) $ page=1; 

else $ page= isset( $_GET[ 'page'])?intval( $ _GET[ 'page ’]):1; 

// 获 取 地 址 栏 中 page 的 值 , 不 存在 则 设 为 1 


$ num= 10; // 每 页 显示 10 条 记录 

$ url = 'Teacher. php'; // 本 页 URL 

$ pagenum = ceil( $ total/ $ num); // 获 得 总 页 数 ,ceil() 返 回 不 小 于 x 的 最 小 整数 页 
$ prepg= $ page— 1; // 上 一 页 


$ nextpg= ( $ page == $ pagenum? 0: $ page + 1); // 下 一 页 
$new_sql= $ sqlstr." limit ".($page—1)* $num.",". $num; 
// 按 每 页 记录 数 生成 查询 语句 
$ new_result =mysql_query( $ new_sql); 
if( $ new_row = @mysql_fetch array( $ new_result)) 
f // 若 有 查询 结果 , 则 以 表格 形式 输出 
do 
{ list($ id, $ name, $ pwd, $ level, $ tel) = $ new_row; // 数 组 的 键 名 从 0 开始 
echo "<tr>"; 
echo "<td width = '20% ><a href = ‘teacher_update. php?id= $ id’>$ id</a></td>"; 
echo "<td width= '15% '>$ name </td>"; 
echo "<td width= '15% ‘>$ pwd </td>"; 
echo "<td width= '15% '>$ level </td>"; 
echo "<td width= '20% '>$ tel </td>"; 
echo "<td width= '15% '>< input type= 'checkbox' name= 'T_id[]'value= '$id'/ 
></td>"; 
echo "</tr >"; 
}while( $ new_row = mysql_fetch_array( $ new_result)); 
// 开 始 分 页 导航 条 代码 
$ pagenav = ""; 
if( $ prepg) 
$ pagenav. = "<a href = '$ url?page = $ prepg'> 上 一 页 </a> "; 
for( $i=1;$i<= $pagenum; $i++) 
{ 
if( $page== $i) $pagenav. ="<B>< font color = '# FF0000'> $i</font ></B> 
Snbsp; "; 
else $ pagenav. =" <ahref = '$url?page= $i'>$i"."gnbsp;</a>"; 
} 
if( $ nextpg) 
$ pagenav. =" <a href = ' $ url?page = $ nextpg'> 下 一 页 </a>"; 
$ pagenav. = "gnbsp; gnbsp; 共 ". $ pagenum. "页 "; 
// 输 出 分 页 导航 





echo "<tr><td colspan = "6'align = 'center'>". $ pagenav. "</td></tr >"; 
} 


else 
echo "<tr><td colspan = '6'align= 'center > 暂 无 记录 </td></tr>"; 


} 


if(isset( $_POST["del"])) // 单 击 “ 删 除 ” 按 钮 ,删除 所 选 数 据 并 重新 加 载 数据 
{ 
$ id= @ $ _POST["T_id"]; //$ id 为 数组 名 
if(! $ id) echo "< script >alert( ' 请 至 少 选择 一 条 记录 ! ') ;</script >"; 
else{ 
$ num = count( $ id); // 使 用 count 函数 取得 数组 中 值 的 个 数 


for( $i=0;$i<$num; $i++) // 使 用 for 循环 删除 所 选 数据 
{ // 若 要 删除 教工 号 为 A 的 教师 ,除非 开课 表 中 没有 教工 号 为 A 的 任教 信息 
$sql="select * from offercourse where teacherid= '$ id[ $i]'"; 
$ rs0 =mysql_query( $ sql); 
if (mysql_num_rows( $ rs0) == 0) 
{ 
$ delsql = "delete from teacher where teacherid= '$ id[ $ i]'"; 
mysql_query( $ delsql); 
} 


} 
echo "< script >alert( ' 操 作 完 成 ! ');</script >"; 


} 
$ sql = "select * from teacher"; 
$ sql = $ sql." where teachername like '%".@ S$ _POST["name"]." $% ' order by teacherid"; 


loadinfo( $ sql); // 加 载 显示 数据 
if(isset( $_POST["add" ])) // 单 击 " 添 加 ”按钮 转 教师 添加 、 修 改 页 面 
{ 
echo "< script > location. href = ‘teacher_add. php';</script >"; 
} 
?> 
<tr> 
<td colspan = '6'align= "center"> 
< input type = 'submit ' name = 'add' value = ' 添 加 ' /> gnbsp; &nbsp; &nbsp; &nbsp; 
< input type = 'submit 'name = 'del' value = ' 删 除 'onClick = "delcfm()" /> 
</td> 
</tr> 
</table> 
</div> 
</form> 
</body> 


2. Teacher_add. php 教师 添加 页 面 
使 用 PHP 脚本 验证 表单 数据 , 当 添 加 一 位 教师 时 , 先 检查 教师 表 是 否 存 在 该 教工 号 ， 
如 果 该 教工 号 已 存在 , 则 提示 重新 输入 。 运 行 界面 如 图 10-5 所 示 。 
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10-5 添加 教师 页 面 


相关 代码 如 下 : 

<head> 

<meta http— equiv = "Content - Type" content = "text/html; charset = utf - 8" /> 
<title > 教师 添加 </title > 


< script src = "../scripts/Com. js"></script > 
< style type = "text/css"> 
= 
.STYLE1 {color: 井 FF0000} 
#table2 { 
width: 500px; 
margin: 0 auto; 
} 
body, td, th { 
font - size: 14px; 
} 
--> 
</style> 
<div style = 'Display:none '> 
<?php 
include "../Fun. php" ; // 选 择 数 据 库 
include "../IsLogin. php"; // 判 断 用 户 是 否 登录 
</div> 
</head> 
<body> 
<?php 
if (isset( $ _REQUEST[ "add" ])) 
{ 
$ test=1; // 只 要 $ test = 0, 则 表单 信息 就 无 法 提交 
$ teacherid = $ _REQUEST[ "teacherid" ]; 
$ teachername = $ _REQUEST["teachername" ]; 
$ pnd= $ _REQUEST[ "pwd" ]; 
$ level = $ _REQUEST[ "level" ]; 
$ tel= $ _REQUEST["tel"]; 
// 若 正则 表达 式 含 、$ ,只 有 正则 表达 式 与 字符 串 完全 匹配 ,该 函数 才 返 回 1 
if( $ teacherid == "") { $ teacheridl = "必须 输 教 工 号 !"; $ test = 0;} 
elseif(preg_match( '/^\d{10} $ /', $ teacherid) == 0) 
{ $ teacherid1 = "教工 号 必须 为 10 位 数字 !"; $ test = 0;} 





else{ $ sql = "select * from teacher where teacherid= '$ teacherid'" 
$ result = mysql_query( $ sql); 
if (mysql_num rows( $ result)>=1) 
{ $ teacheridl = "输入 的 教工 号 已 经 存在 , 请 重 输 !"; $ test = 0;} 


} 
if ( $ teachername == "") { $ teachernamel = "必须 输入 姓名 !"; $ test = 0;} 
if ($ pwd=="") {$ pwdl = "必须 输入 密码 !"; $ test = 0;} 
if ($level=="") {$levell = "必须 选择 职称 !"; $ test = 0;} 
证 ( $ tes: 1) 
{ $sql="insert into teacher 
values( ' $ teacherid', ' $ teachername’', '$ pwd', '$ level' '$ tel’)"; 
mysql_query( $ sql); 
echo "< script language = 'javascript '> alert( ' 插 入 成 功 ! ');</script >"; 
} 








} 
x 
< table border = "0" cellpadding = "0" cellspacing = "0" width= "100%" id= "tablel"> 
<tr> 
<td><form action="" method = "post" name = "forml" > 
< table border = "1" cellpadding = "4" cellspacing = "0" width = "500px" id = "table2" 
bordercolor = " #328EBE"> 
<tr> 
<td colspan = "2" align = "center”bgcolor = " 井 328EBE"> 添加 教师 信息 </td> 
</tr> 
<tr> 
<tdwidth="25%" align= "center" > 教工 号 </td> 
< td width = "75%" align = "left">< input type = "text" name = "teacherid" jd = 
"teacherid" /> < font color = "#FF0000"> * </font ><?php echo "< font size= '2'color = 
‘FF0000 >". @ $ teacheridl. "</font >";?></td> 
</tr> 
<tr> 
<tdwidth="25%" align = "center"> 姓 名 </td> 
<tdwidth= "75%" align = "left">< input type = "text" name = "teachername" id = 
"teachername" /> 
< font color = "##FF0000">* </font ><?php echo "< font size = '2' color = 'FF0000 '>". 
@ $ teachernamel."</font >";?> 
</td> 
</tr> 
<tr> 
<tdwidth="25%" align = "center"> 密 码 </td> 
<td width="75$" align= "left">< input type = "password" name = "pwd" size = "24" 
value="" id= "pwd"/> 
< font color =" 井 FF0000"> * </font ><?php echo "<font size = '2' color = 'FF0000 >".@ 
$ pwdl. "</font >";?> </td> 
</tr> 
<tr> 
<tdwidth="25%" align= "center"> 职 称 </td> 
<tdwidth="75% "align= "left">< select name = "level" id= "level"> 
< option value = ""> 请 选择 职称 </option> 
< option > 助教 </option> 
<option > 讲师 </option > 
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< option > 副教授 </option > 
<option > 教授 </option> 
</select> 


< font color =" 间 FF0000"> * </font ><?php echo "<font size = '2' color = 'FF0000 >".@ 
$ levell. "</font >";?></td> 
</tr> 
<tr> 
<tdwidth= "25%" align= "center"> 手 机 </td> 
<tdwidth="75%" align= "left">< input type = "text" name = "tel" size="25" value = 
"" id= "tel"/></td> 







</tr> 
<tr> 
< td colspal " align = "center" bgcolor = "#328EBE"> 
< input typ: submit" name = "add" value = "添加 " /> 
< input type = " reset" name = "back2” value = "返回 " onclick = " location. href = 
‘teacher. php'"/> 
</td> 
</tr> 
</table ></form></td> 
</tr> 
</table> 
</body > 


3. Teacher_update. php 修改 教师 信息 页 面 

首先 接收 从 Teacher. php 页 面 传送 过 来 的 教工 号 ,然后 显示 该 教师 的 教工 号 .姓名 、 密 
码 、 职 称 和 手机 号 码 。 教 工 号 是 主键 ,不 能 修改 ,但 允许 管理 员 修 改 教师 的 其 他 信息 。 运 行 
界面 如 图 10-6 所 示 。 









































| 修改 ] 


图 10-6 修改 教师 信息 页 面 





相关 代码 如 下 : 


<head> 
<meta http— equiv = "Content - Type" content = "text/html; charset = utf— 8" /> 
<title> 教 师 修 改 </title> 
< Script src ="../scripts/Com. js"></script > 
<style type = "text/css"> 
和 
.STYLE1 {color: #FF0000} 
#table2 { 
width: 500px; 





margin: 0 auto; 


} 
body, td, th { font — size: 14px; } 
-—> 
</style> 
<div style = 'Display:none '> 
<?php 
include "../Fun. php"; // 选 择 数据 库 
include "../IsLogin. php"; // 判 断 用 户 是 否 登录 
和 
</div> 
</head> 
<body> 
<?php 
$ teacherid= $ _REQUEST[ "id" ]; // 教 工 号 是 主键 , 不 能 修改 
if (isset( $ _REQUEST[ "update"])) 
{ 
$ test=1; // 只 要 $ test = 0, 表单 信息 就 无 法 提交 
$ teachername = $ _REQUEST["teachername" ]; 
$ pnd = $ _REQUEST[ "pwd"]; 
$ level = $ _REQUEST["level" ]; 
$ tel = $ _REQUEST[ "tel"]; 
// 若 正则 表达 式 含 “、$ ,只 有 正则 表达 式 与 字符 串 完全 匹配 ,该 函数 才 返 回 1 
if ( $ teachername == "") { $ teachernamel = "必须 输入 姓名 !"; $ test = 0;} 
if ( $ pwd= ) {$ pwdl = "必须 输入 密码 !"; $ test = 0;} 
if ( $ level ) { $ levell = "必须 选择 职称 !"; $ test = 0;} 
if ( $ test==1) 
{ 5$ sql = "update teacher set teachername = ' $ teachername', pnd = '$ pwd', level= '$ level’, 
tel = '$ tel' where teacherid= '$ teacherid"; 
mysql_query( $ sql); 
echo "< script language = 'javascript '> alert( ' 修 改 成 功 ! ');</script >"; 
} 
} 
$sql="select * from teacher where teacherid= '$ teacherid'"; 
$ result =mysql_query( $ sql); 
$ row = mysql_fetch assoc( $ result); 
$ teachername = $ row["teachername" ]; 
$ pwd = $ row[ "pwd" ]; 
$level = $ row["level"]; 
$ tel= $ row["tel"]; 
?> 
< table border = "0" cellpadding = "0" cellspacing = "0" width="100%" id= "tablel"> 
tr 
<td> < form action="" method = "post" name = "forml" > 











< table border = "1" cellpadding = "4" cellspacing = "0" width = "500px" id = "table2" 


bordercolor = " #328EBE"> 
<tr> 
<td colspan = "2" align = "center" bgcolor =" 井 328EBE"> 修改 教师 信息 </td> 
</tr> 
<tr> 
<tdwidth="25%" align= "center" > 教工 号 </td> 
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<td width= "75$% "align= "left">< input name = "id" type= "text" id= "id" readonly = 
"readonly" value = "<?php echo $ teacherid;?>"/></td> 

</tr> 

«tr 
<tdwidth="25%" align= "center"> 姓 名 </td> 





<td width = 
"teachername" value = "<?php echo $ teachername;?>"/> 
< font color = "##FF0000"> * </ font ><?php echo "<font size = '2'color = 'FF0000>".@ 
$ teachernamel. "</font >";?> 
</td> 
</tr> 
<tr> 
<td width = "25$" align = "center"> 密 码 </td> 
<tdwidth="75%" align= "left">< input type = "password" name = "pwd" id = "pwd" 
value = "<?php echo $ pwd;?>"/> 
< font color = "##FF0000">* </font ><?php echo "< font size = '2' color = 'FF0000 >". 
@ 5$ pwdl."</font >";?> </td> 
</tr> 
<tr> 
<td width= "25%" align= "center"> 职 称 </td> 
<tdwidth="75%" align= "left">< select name = "level" id= "level"> 
< option value =""> 请 选择 职称 </option> 
<option <?php if ( $ level == "助教 ") echo "selected" ;?>> 助 教 </option > 
<option <?php if ( $ level == "讲师 ") echo "selected" ;?>> 讲 师 </option > 
<option <?php if ( $ level == "副教授 ") echo "selected";?>> 副 教授 </option> 
< option <?php if ( $ level == "教授 ") echo "selected" ;?>> 教 授 </option > 
</select > 
< font color =" 井 FF0000"> * </font ><?php echo "<font size = '2' color = 'FF0000>".@ 
$ levell. "</font >";?></td> 
</tr> 
<tr> 
<tdwidth="25%" align= "center"> 手 机 </td> 
<tdwidth= "75%" align= "left">< input type = "text" name = "tel" size="25" id= "tel" 
value= "<?php echo $ tel;?>"/></td> 


"75$ "align = "left">< input type = "text" name = "teachername" jid = 









</tr><tr> 
< td colspan = "2" align = "center" bgcolor = "#328EBE"> 
< input type = "submit" name = "update" value = "修改 " id= "update" /> 


< input type = " reset" name = "back2" value = "返回 "onclick = "location. href = 
'teacher. php '"/> 
</td> 
</tr> 
</table></form></td> 
</tr> 
</table> 
</body> 


10.4.2 班级 管理 


1. Class. php 班级 查询 .删除 页 面 
系统 首先 分 页 查询 全 部 班级 的 信息 . 若 输 入 专业 名 称 的 关键 字 , 则 模糊 查询 相应 专业 的 





班级 信息 。 选 择 班级 记录 ,并 单 击 “ 删 除 "按钮 , 即 删除 选中 的 班级 记录 ; 单 击 “ 添 加 ”按钮 ， 
显示 记录 添加 页 面 ; 单 击 某 条 记录 的 超 链接 ,显示 该 记录 的 修改 页 面 。 运 行 界面 如 图 10-7 


所 示 。 

































































请 输入 专业 名 称 : 
班 明 序 号 入 字 年 份 专业 名 称 班 名 
140101 2014 计算 机 应 用 技术 ] 班 47 中 
140102 2014 计算 机 应 用 技术 2 班 47 口 
140201 2014 计算 机 网 络 技 术 ] 班 39 [本 
140202 2014 计算 机 网 络 技术 王 40 口 
140203 2014 计算 机 网 络 技 术 3 班 38 号 
140204 2014 计算 机 网 络 技术 三 37 口 
150101 2015 计算 机 应 用 技术 8 52 日 
150102 2015 计算 机 应 用 技术 三 53 口 
150201 2015 计算 机 网 络 技术 二 4 日 
150202 2015 计算 机 网 络 技 术 p23 42 口 
1 2 3 下 一 页 共 3 页 
[es] 
图 10-7 班级 查询 删除 页 面 
相关 代码 如 下 : 
<head> 


<meta http— equiv = "Content - Type" content = "text/html; charset =utf -8" /> 





< link href ="../styles/com. css" rel = "stylesheet" /> 
< style type = "text/css"> 
table { 

width: 70%; 


margin: 0 auto; 


: 





</style> 

< script src = "../scripts/Com. js"></script > 
<title> 班 级 信息 </title> 

</head > 

<body> 


< form method = "post" name = "forml"> 
<div align ="center"> 
< font style = "font - family: ' 华 文 新 魏 '; font - size:20px" > 班级 管理 </font ><br> 
请 输入 专业 名 称 : 
< input namt major" type = "text" id= "major" size= "20" /> 
< input name = "search" type = "submit"” value = "查询 "/> 
<table> 
<thead> 
te> 
<th width = "20 $% "> 班级 序号 </th> 
<th width= "10g% "> 人 学 年 份 </th> 
<th width= "25 $% "> 专业 名 称 </th> 
<th width= "15 $% "> 班 名 </th> 
<th width= "10g%"> 班 人 数 </th> 
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<thwidth= "20% "> 删除 < input type = 'checkbox' id= 'CBox' onClick = 'checkall(this. form) '/> 
</th> 


</tr> 
</thead> 
<?php 
include "../Fun. php"; // 连 接 数 据 库 
include "../IsLogin. php"; 
function loadinfo( $ sqlstr) 


{ 


$ result = mysql_query( $ sqlstr); 

$ total = mysql_num_rows( $ result); // 记 录 总 条 数 $ total 

证 (isset( $ _REQUEST["search"])) $ page=1; // 单 击 * 查 询 " 按 钮 ,总 是 从 第 1 页 开始 显示 
else $ page = isset( $_REQUEST[ ‘page'])?intval( $ _REQUEST[ ‘page']):1; 

// 获 取 地 址 栏 中 page 的 值 , 若 不 存在 则 设 为 1 


$ num = 10; // 每 页 显示 10 条 记录 

$ url= 'Class. php'; // 本 页 URL 

$ pagenum = ceil( $ total/ $ num); // 获 得 总 页 数 ,ceil() 返 回 不 小 于 x 的 最 小 整数 
$ page = min( $ pagenum, $ page); // 获 当前 页 ,min() 取 得 较 小 数 

$ prepg= $ page— 1; /A/ 上 一 页 


$ nextpg= ( $ page == $ pagenum? 0: $ page+1); // 下 一 页 
//1imit m,n: 从 mt+1l 号 记录 开始 , 共 检 索 n 条 记录 
$ new_sql = $ sqlstr." limit ".( $ page— 1) * $ nom.",". $ num; // 按 每 页 记录 数 生 成 查询 语句 
$ new_result = mysql_query( $ new_sql); 
if( $ new_row= @mysql_fetch array( $ new_result)) 
{ 
// 若 有 查询 结果 , 则 以 表格 形式 输出 
do 
{ 
list( $ classid, $ enrollyear, $ major, $ classname, $ num) = $ new_row; 
// 数 组 的 键 名 从 0 开始 
echo "<tr>"; 
echo "< td width = '20% ><a href = 'class_update. php?id= $ classid'> $ classid</a> 
</td>"; 
echo "<td width= '10% '>$ enrollyear </td>"; 
echo "<td width= '25% '>$ major </td>"; 
echo "<td width= '15% '>$ classname </td>"; 
echo "<td width= '10% >$ num </td>"; 
echo "<td width = '20% >< input type = 'checkbox' name = 'T_id[] 'value= '$ classid'/ 
></td>"; 
echo "</tr >"; 
}while( $ new_row = mysql_fetch_array( $ new_result)); 
// 开 始 分 页 导航 条 代码 
$ pagenav = ""; 
if( $ prepg) // 如 果 当 前 显示 第 一 页 , 则 不 会 出 现 "上 一 页 ” 
$ pagenav. = "<a href = '$ url?page = $ prepg'> 上 一 页 </a> "; 
for( $i=1;$i<= $pagenum; $i++) //$ pagenum 为 总 页 数 
{ 
if( $ page== $i) $ pagenav. ="<b>< font color = '#FF0000'> $i</font ></b> 
Snbsp; "; 
else $ pagenav. =" <ahref = '$url?page= $i'>$i"."gnbsp;</a>"; 
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if( $ nextpg) // 如 果 当 前 显示 最 后 一 页 , 则 不 会 出 现 "下 一 页 " 
$ pagenav. = " <a href = ' $ url?page = $ nextpg'> 下 一 页 </a>"; 
$ pagenav. = "gnbsp; Snbsp; 共 ". $ pagenum. "页 "; 
// 输 出 分 页 导航 
echo "<tr><td colspan = '6'align = 'center'>". $ pagenav."</td></tr>"; 


} 
else 
echo "<tr><td colspan = '6' align = 'center > 暂 无 记录 </td></tr>"; 
} 
if(isset( $_POST["del"])) // 单 击 * 删 除 "按钮 
{ 
$ id= @ $ _POST[ "T_id"]; //$ id 为 数组 名 
if(! $ id) echo "< script >alert( ' 请 至 少 选择 一 条 记录 ! ');</script >"; 
else{ 
$ num = count( $ id); // 使 用 count 函数 取得 数组 中 值 的 个 数 
for( $i=0;$i<$num; $it+) // 使 用 for 循环 删除 所 选 数据 
| 
// 要 删除 班级 序号 为 A 的 记录 ,除非 学 生 表 、 开 课表 中 尚 没有 班级 序号 为 A 的 记录 
$sql="select * from student where classid= '$ id[ $i] '"; 
$ rs0=mysql_query( $ sql); 
$sql="select * from offercourse where classid= '$ id[ $i]'"; 
$ rsl=mysql_query( $ sql); 
if (mysql_num_rows( $ rs0) == 0 && mysql_num_rows( $ rs1) == 0) 
{ $ delsql = "delete from class where classid= '$ id[ $i]'"; 
mysql_query( $ delsql); 
} 
} 
echo "< script >alert( ' 操 作 完 成 ! ');</script >"; 
} 
} 
$ major = @ $ _REQUEST[ "major" ] ; 
if ($major=="") $sql="select * from class order by classid"; 


else $ sql = "select * from class where majorname like ‘%". $major."% 'order by classid"; 
loadinfo( $ sql); 
if(isset( $_POST["add" ])) // 单 击 * 添 加 ”按钮 转向 班级 增加 页 面 
{ 
echo "< script > location. href = ‘class_add. php ';</script >"; 
} 
?> 
<tr> 
<td colspan = "6" align = "center">< input type = "submit” name = "add" value = "添加 "/> 
gnbsp; &nbsp; &nbsp; &nbsp; < input type = 'submit ' name = "del" value = "删除 ”onClick = 
"delcfm()" /></td> 
</tr> 
</table> 
</div> 
</form> 
</body > 


2. Class_add. php 班级 添加 页 面 
使 用 PHP 脚本 验证 表单 数据 , 当 添加 一 个 班级 时 , 先 检查 班级 表 是 否 存在 该 班级 序 
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10-8 班级 添加 页 面 


相关 代码 如 下 : 


<head> 


<meta http - equiv = "Content - Type" content = "text/html; charset =utf -8" /> 


<title > 班级 添加 </title> 

<script src="../scripts/Com. js"></script > 
< style type = "text/css"> 

<! —— 

.STYLE1 {color: 井 FEF0000} 


#table2 { 
width: 500px; 
margin: 0 auto; 


body, td, th { 


font ~ size: 14px; 


-一 > 
</style> 
<div style = 'Display:none '> 
<?pPhp 
include "../Fun. php"; // 选 择 数据 库 


include "../IsLogin. php" ; // 判 断 用 户 是 否 登录 


</div> 
</head> 
<body> 
<?php 


if (isset( $ _REQUEST[ "add" ])) 
{ 
$ test =1; // 只 要 $ test = 0, 表单 信息 就 无 法 提交 
$ classid= $ _REQUEST["classid" ]; 
$ enrollyear = $ _REQUEST["enrollyear" ]; 
$ majorname = $ _REQUEST[ "majorname" ]; 
$ classname = $ _REQUEST[ "classname" ]; 
$ num= $ _REQUEST[ "num" ]; 
// 若 正则 表达 式 含 ^、$ ,只 有 正则 表达 式 与 字符 串 完 全 匹配 ,该 函数 才 返 回 1 
if( $classid=="") { $ classidl = "必须 输入 班级 序号 !"; $ test = 0;} 




















elseif(preg_match( '/^\d{6} $ /', $ classid) ==0) 
{$classidl = "班级 序号 必须 为 6 位 数字 !"; $ test = 0;} 
else { $ sql ="select * from class where classid= '$ classid'"; 
$ result = mysql_query( $ sql); 
if (mysql_num_rows( $ result)>=1) 
{$classidl = "输入 的 班级 序号 已 经 存在 , 请 重 输 !"; $ test = 0;} 


} 
if ( $ enrollyear= 





) { $ enrollyearl = "必须 选择 人 学 年 份 !" ; $ test = 0;} 
必须 输入 专业 名 称 !"; $ test = 0;} 
须 选择 班 名 !"; $ test = 0;} 
) {$numl = "必须 输入 班 人 数 !"; $ test = 0;} 
) 
{$sql="insert into class values('$ classid', $ enrollyear, ' $ majorname', ' $ classname’, 
$ num)"; 
mysql_query( $ sql); 
echo "< script language = 'javascript '> alert( ' 插 入 成 功 ! ');</script >"; 
} 
} 
?> 
< table border = "0" cellpadding = "0" cellspacing = "0" width= "100%" id= "tablel"> 
EE 
<td><form action="" method = "post" name= "forml" > 
< table border = "1" cellpadding = "4" cellspacing = "0" width = "500px" id = "table2" 
bordercolor = " #328EBE"> 
<tr> 
<td colspan = "2" align = "center"” bgcolor = " 间 328EBE"> 添加 班级 信息 </td> 
</tr> 
<tr> 
<tdwidth="25%" align= "center" > 班级 序号 </td> 
<tdwidth="75%" align = "left">< input type = "text" name = "classid" jd = 
"classid" /><?php echo "<font size= '2' color = ‘FF0000 '>". @ $ classidl. "</font >"; 
?></td> 
</tr> 
<tr> 
<?php $ x= getdate(); 
$year = $ x["year"]; ?> 
<tdwidth="25%" align= "center"> 人 学 年 份 </td> 
<td width= "75g% " align= "left">< select name = "enrollyear" id = "enrollyear"> 
<option value = ""> 请 选择 年 份 </option> 
<option ><?php echo $ year — 3;?></option> 
<option><?php echo $ year — 2;?></option> 
<option><?php echo $ year — 1;?></option> 
< option ><?php echo $ year;?></option> 
</select ><?php echo "< font size= '2' color = 'FF0000 >". @ $ enrollyearl. "</font >";?> 
</td> 
</tr> 
<tr> 
<tdwidth="25% "align= "center"> 专 业 名 称 </td> 
<tdwidth="75%" align = "left">< input type = "text" name = "majorname" size= 
"25" value = "" id= "majorname"/><?php echo "< font size= '2'color= 'FF0000>".@ 
$ majornamel. "</font >" ;?> </td> 
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</tr> 
<tr> 
<td width= "25% " align = "center"> 班 名 </td> 
<td width="75%" align = "left">< select name = "classname" id = "classname"> 
<option value = ""> 请 选择 班 名 </option> 
< option > 班 </option> 
<option>1 班 </option> 
<option>2 班 </option > 
<option>3 班 </option> 
<option>4 班 </option > 
<option>5 班 </option> 
</ select ><?php echo "< font size = '2' color= 'FF0000 >".@ $ classnamel."</font >";?> 
</td> 
</tr> 
<tr> 
<tdwidth="25%" align= "center"> 班 人 数 </td> 





<tdwidth= "75%" align = "left">< input type = "text" name= "num" size = "25" value 
= ""/><?php echo "< font size = ‘2'color= ‘FF0000'>".@ $ numl."</font >";?></td> 
</tr> 
<tr> 


<td colspan = "2" align = "center" bgcolor = "#328EBE"> 
< input type = "submit" name = "add" value = "添加 " /> 
< input type = "reset" name = "back2” value = "返回 ”onclick = "location. href = 
‘Class. php'"/> 
</td> 
</tr> 
</table ></form></td> 
</tr> 
</table> 
</body > 


3. Class_update. php 班级 修改 页 面 
首先 接收 从 Class. php 页 面 传送 过 来 的 班级 序号 ,然后 显示 该 班级 的 班级 序号 、 入 学 稀 


份 , 专 业 名 称 ` 班 名 和 班 人 数 。 班 级 序号 是 主键 ,不 能 修改 ,但 允许 管理 员 修改 班级 的 其 他 信 
息 。 相 关 代码 如 下 : 


mm 





<head> 

<meta http ~ equiv = "Content - Type" content = "text/html; charset = utf - 8" /> 
<title > 班级 修改 </title> 

< script src = "../scripts/Com. js"></script > 

<style type = "text/css"> 

-== 

.STYLE1 {color: #FF0000} 

#table2 { 


width: 500px; 
margin: 0 auto; 

} 

body, td, th { 
font — size: 14px; 





== 区 
</style> 
< div style = 'Display:none'> 
<?php 
include "../Fun. php"; // 选 择 数据 库 
include "../IsLogin. php"; // 判 断 用 户 是 否 登录 
?> 
</div> 
</head > 
<body> 
<?php 
$ classid = $ _REQUEST[ "id" ]; // 班 级 序号 是 主键 ,不 能 修改 
if (isset( $ _REQUEST[ "update"])) 
{ 

$ test=1; // 只 要 $ test = 0, 表 单 信息 就 无 法 提交 

$ enrollyear = $ _REQUEST["enrollyear" ]; 

$ majorname = $ _REQUEST[ "majorname" ]; 

$ classname = $ _REQUEST["classname" ]; 

$ num= $ _REQUEST[ "num" ]; 

if ($enrollyear =="") { $ enrollyearl = "必须 选择 人 学 年 份 !"; $ test = 0;} 

if ($majorname == "") { $majornamel = "必须 输入 专业 名 称 !"; $ test = 0;} 

if ( $ classnam "") {$classnamel = "必须 选择 班 名 !"; $ test = 0;} 

if ($num=="") {$numl = "必须 输入 班 人 数 !"; $ test = 0;} 

if ($test==1) 

{ $ sql = "update class set enrollyear = $ enrollyear,majorname = '$ majorname 
classname = '$ classname',num = $ num where classid= ' $ classid'"; 
mysql_query( $ sql); 
echo "< script language = 'javascript '> alert( ' 修 改 成 功 ! ') ;</script >"; 











} 
$sql="select * from class where classid= '$ classid"; 
$result =mysql_query( $ sql); 
$ row = mysql_fetch assoc( $ result); 
$classid= $ row[ "classid"]; 
S$ enrollyear = $ row["enrollyear"]; 
$ majorname = $ row[ "majorname" ]; 
$classname = $ row[ "classname"]; 
$num= $ row[ "num" ]; 
?> 
<table border = 
<tr> 
<td> < form action="" method = "post" name= "forml" > 
< table border = "1" cellpadding = "4" cellspacing = "0" width = "500px" id = "table2" 
bordercolor = " #328EBE"> 
<tr> 
<td colspan = "2" align = "center" bgcolor = " 间 328EBE"> 修改 班级 信息 </td> 
</tr> 
<tr> 
<td width = "25%" align = "center" > 班级 序号 </td> 
<td width= "75%" align= "left">< input name = "id" type= "text" id= "id" value= 
"<?php echo $ classid;?>" readonly = "readonly"/></td> 





cellpadding = "0" cellspacing = "0" width="100%" id= "tablel"> 
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</tr> 
二 
<?php $ x= getdate( ) 
$year = $x["year"]; 
?> 
<tdwidth="25%" align= "center"> 人 学 年 份 </td> 
<td width= "75 委 "align= "left">< select name = "enrollyear" id= "enrollyear"> 
< option value = ""> 请 选择 年 份 </option> 
< option <?php if ( $ enrollyear == $ year - 3) echo "selected";?>><?php echo 
$ year — 3;?></option> 
< option <?php if ( $ enrollyear == $ year - 2) echo "selected";?>><?php echo 
$ year — 2;?></option> 
< option <?php if ( $ enrollyear == $ year - 1) echo "selected";?>><?php echo 
$ year 一 1;?></option> 
< option <?php if ( $ enrollyear == $ year) echo "selected";?>><?php echo $ year;?> 
</option> 
</ select ><?php echo "< font size= '2'color= 'FF0000 >". @ $ enrollyearl. "</font >";?> 
</td> 
</tr> 
<tr> 
<tdwidth="25%" align= "center"> 专 业 名 称 </td> 
<tdwidth= "75%" align = "left">< input type = "text" name = "majorname" size = 
"25" value = "<?php echo $ majorname;?>" id= "majorname"/><?php echo "<font size= 
'2' color = 'FF0000'>". @ $ majornamel. "</font >";?> </td> 
</tr> 
<tr> 
<td width= "25%" align= "center"> 班 名 </td> 
<tdwidth="75%" align= "left">< select name = "classname" jd = "classname"> 
< option value =""> 请 选择 班 名 </option> 
<option <?php if ( $ classname == " 班 ") echo "selected";?>> 班 </option> 
< option <?php if ( $ classname == "1 班 ") echo "selected";?>>1 班 </option> 
< option <?php if ( $ classnam "2 班 ") echo "selected";?>>2 班 </option> 
< option <?php if ( $ classname 3 班 ") echo "selected";?>> 3 班 </option > 
<option <?php if ( $ classname == "4 班 ") echo "selected";?>> 4 班 </option> 
<option <?php if ( $ classname == "5 班 ") echo "selected";?>>5 班 </option > 
</select ><?php echo "< font size= '2' color= ‘FF0000'>". @ $ classnamel. 
"</font >";?></td> 
</tr> 
<tr> 
<tdwidth="25% "align= "center"> 班 人 数 </td> 
<tdwidth= "75%" align= "left">< input type = "text" name = "num" size= "25" value 
"<?php echo $ num;?>"/><?php echo "< font size= '2'color= ‘FF0000'>".@ $ numl. 
"</font >";?></td> 
</tr> 
<tr> 
<td colspan = "2" align = "center" bgcolor = "#328EBE"> 
< input type = "submit" name = "update" value = "修改 " id= "update" /> 
< input type = "reset" name = "back2" value = "返回 ”onclick = " location. href = 
'Class. php""/> 
</td> 
</tr> 
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</table ></form></td> 
</tr> 
</table> 
</body > 


10.4.3 ”学 生 学 籍 管 理 


1. Student. php 学 生 查询 ,删除 页 面 

系统 起 始 仅 显示 查询 顶部 , 当 系 统管 理 员 选 择 一 个 专业 后 ,才能 级 联 出 该 专业 的 所 有 班 
级 , 当 系 统管 理 员 再 选择 一 个 班级 ,并 单 击 “ 查 询 ” 按 钮 后 ,页 面 才 会 分 页 显示 查询 结果 。 选 
择 某 些 学 生 记录 ,并 单 击 " 删 除 " 按 钮 时 , 即 删除 选中 的 学 生 记 录 ; 单 击 “ 添 加 ”按钮 ,显示 记 
录 添 加 页 面 ; 单 击 某 条 记录 的 超 链接 ,显示 该 记录 的 修改 页 面 。 运 行 界面 如 图 10-9 所 示 。 
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2015 计 算 机 网 络 技术 1 班 学 生 名 单 
学 ”姓名 ”人 性别 ”出 生日 其 天 级 谨 号 ”总 字 分 “一 肝 下 
1530505101| 李 岂 竣 | 男 | 1992-01-01 | 150201 | 0 | 吕 
1530505102 | 陈 芳 中 | 男 | 1992-01-01 | 150201 0 | 日 
1530505103| 邑人 发 | 男 | 1992-01-01 | 150201 0 口 
1530505104| 庄 拉 敏 | 女 | 1992-01-01 | 150201 0 | 悍 
1530505105 | 陈 月 得 | 女 | 1992-01-01 | 150201 0 加 | 
1530505106 | 谢 佛 强 男 | 1992-01-01 150201 0 可 | 
1530505107 | 邓 的 元 | 男 | 1992-01-01 | 150201 0 | 日 
1530505108 | 黄 志 德 |。 男 | 1992-01-01 | 150201 0 | 日 
1530505109 郭 梓 输 男 1992-01-01 150201 0 | 口 
1530505110 | 陈 人 本 | 男 | 1992-01-01 | 150201 o | 
1 2 3 4 下 -页 共 4 页 
[ms] 
图 10-9 学 生 查 询 删除 页 面 
相关 代码 如 下 : 


<head> 
<meta http - equiv = "Content - Type" content = "text/html; charset =utf -8" /> 
<1ink href ="../styles/com. css" rel = "stylesheet" /> 
<style type = "text/css"> 
table { 
width: 80%; 
margin: 0 auto; 
} 
</style> 
< script src="../scripts/Com. js"></script > 
<title> 学 生 信息 </title> 
<div style = 'Display:none> 
<?php 
include "../Fun. php"; 
include "../IsLogin. php"; 








% 


</div> 

</head> 

<body> 

< script type = "text/javascript"> 
// 选 择 专业 改变 班级 


function change( ) 
{ 
Var bms = document. forml .major. value; 
if (bms =="") {window.alert(" 专 业 名 不 能 为 空 "); document. forml. major. focus();} 
var bm = bms. split("|"); 
// 按 "1" 将 bms 分 成 若干 子 串 , 并 依次 存 人 数组 中 , bm 的 长 度 为 "| "的 个 数 +1 
for(i=0;i<(bm. length—1)/2;i++) 
//classl 的 value 值 为 班级 序号 ,text 值 为 "入 学 年 份 - 班 名 " 
{ with(document. forml. classl) 
{ length = (bm.length— 1)/2+1; 
options[i+1].value = bm[2*i]; 
options[i+1].text =bm[2xi+1]; 





} 
function checkclass( ) 
{ 
if (document. forml.classl. value == "") 
{ 
alert(" 请 选择 专业 班 !"); 
document. forml .classl. focus( ); 
return false; 
} 
</script > 
< form method= "post" name = "forml"> 
<div align = "center"> 
< font style = "font - family: ' 华 文 新 魏 '; font - size:20px" > 学 生 学 籍 管理 </font ><br /> 
<select name = "major" jd = "major" onChange = "change()"> 
<option value = "" > 请 选择 专业 </option> 
<?php 
$ sqlx = "select distinct majorname from class"; 
$ rsl=mysql_query( $ sqlx); 
$rowl = mysql_fetch_assoc( $ rs1); 
// 每 取出 一 个 专业 ,就 输出 其 全 部 班级 
while( $ row1) 
{ $zy= $rowl["majorname"]; 
$ sqlx = "select distinct classid, enrollyear, classname from class where majorname = '$ zy 
$ rs2= mysql_query( $ sqlx); 
$ row2 = mysql_fetch assoc( $ rs2); 
$class=""; 
while( $ row2) 
{ S$class.= $row2["classid"]."|". $ row2["enrollyear"]."—". $ row2["classname"]. 
$ row2 = mysql_fetch_assoc( $ rs2); 


区 





<option value = "<?php echo $ class;?>"><?php echo $ rowl["majorname"];?></option> 
<?php 
$ rowl = mysql_fetch_assoc( $ rs1); 
} 
?> 
</select> 
<select name= "classl" id= "classl"> 
<option value = "" > 请 选择 班级 </option > 
</select> 
gnbsp;< input name = "search" type = "submit" value = "查询 " onclick = "return checkclass()"/> 
<br /> 
<?php // 只 有 单 击 “查询 "按钮 或 地 址 栏 page 有 值 , 才 能 显示 记录 
if(isset( $ _REQUEST["search"]) || isset( $ _REQUEST["page" ])) 
{ if(isset( $_REQUEST["search"])) $ _SESSION["classid"] = $ _REQUEST["class1"]; 
$ sqlx= "select * from class where classid= '". $ _SESSION["classid"]."'"; 
$ rs3= mysql_query( $ sqlx); 
$ row3 = mysql_fetch_assoc( $ rs3); 
echo $ row3["enrollyear"]. $ row3["majorname"]. $ row3["classname"]. "学生 名 单 "; 


} 
?> 
<table> 
<thead> 
<tr> 
<thwidth="12% "> 学 号 </th> 
<th width= "125% "> 姓名 </th> 
<th width= "125$ "> 性 别 </th> 
<th width="20g% "> 出 生日 期 </th> 
<th width = "20% "> 班级 序号 </th> 
<th width="12% "> 总 学 分 </th> 
<th width = "12% "> 删除 < input type = 'checkbox' id= 'CBox' onClick = ‘checkall 
(this. form) '/></th> 
</tr> 
</thead > 
<?php 
if(isset( $ _REQUEST[ "del" ])) // 单 击 * 删 除 "按钮 ,删除 所 选 数 据 并 重新 加 载 数据 


{ 
$ id= @ $ _REQUEST[ "T_id" ]; 1/$ id 为 数组 名 
if(! $ id) echo "< script >alert( ' 请 至 少 选择 一 条 记录 ! ');</script >"; 
else{ 
$ num= count( $ id); // 使 用 count 函数 取得 数组 中 值 的 个 数 
for( $i=0;$i<$nuom; $it+) // 使 用 for 循环 删除 所 选 数据 
{ $ delsql = "delete from student where studentid= '$ id[ $ i] "; 
mysql_query( $ delsql); 
// 在 删除 学 号 为 A 的 学 生 时 ,将 同时 删除 成 绩 表 中 学 号 为 A 的 记录 . 
$ delsql = "delete from score where studentid= '$ id[ $ i] '"; 
mysql_query( $ delsql); 
} 
echo "< script >alert( ' 删 除 成 功 ! ');</script >"; 
} 
$ sql = "select * from student where classid= '". $ _SESSION["classid"]."'"; 
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if (!isset( $ _REQUEST[ "page"])) loadinfo( $ sql); 
} 
if(isset( $ _REQUEST[ "search"]) || isset( $ _REQUEST["page"])) 
// 只 有 单 击 “ 查 询 " 按 钮 或 地 址 栏 page 有 值 ,才能 显示 记录 
{ 
$sql="select * from student where classid= '". $ _SESSION["classid"]."'"; 
loadinfo( $ sql); 
} 
function loadinfo( $ sqlstr) 
{ 
$ result = mysql_query( $ sqlstr); 
$ total = mysql_num_rows( $ result); 
证 (isset( $ _REQUEST[ "search"])) $ page=1;  // 每 次 单 击 “ 查 询 " 按 钮 ,从 第 1 页 开始 显示 
else $ page = isset( $ _REQUEST[ 'page '])?intval( $ _REQUEST[ ‘page']):1; 
// 获 取 地 址 栏 中 page 的 值 ,不 存在 则 设 为 1 


$ num= 15; // 每 页 显示 15 条 记录 

$ url = 'Student. php’'; // 本 页 URL 

$ pagenum = ceil( $ total/ $ num) ; // 获 得 总 页 数 ,ceil( ) 返 回 不 小 于 x 的 最 小 整数 
$ prepg= $ page— 1; // 上 一 页 


$ nextpg= ( $ page == $ pagenum? 0: $ page+1); // 下 一 页 
//1limit m,n: 从 m+ 1 号 记录 开始 , 共 检 索 n 条 
$new_sql= $ sqlstr." limit ".( $ page— 1)* $ num.",". $ num; // 按 每 页 记录 数 生 成 查询 语句 
S$ new_result = mysql_query( $ new_sql); 
if( $ new_row = @mysql_fetch_array( $ new_result)) 
// 数 组 $ new_row 的 键 名 可 为 整数 或 字段 名 
E // 若 有 查询 结果 ,以 表格 形式 输出 
do 
{ list( $ id, $ name, $ pwd, $ sex, $ birthday, $ classid, $ credit) = $ new_row; 
// 数 组 的 键 名 为 从 0 开始 的 连续 整数 . 
echo "<tr>"; 
echo "<td width = '12% '><a href = 'Student_update. php?id= $ id'>$ id</a></td>"; 
echo "<td width= '12% '>$ name </td>"; 
echo "<td width= '12% '>$ sex </td>"; 
echo "<td width = '20% '>$ birthday </td >"; 
echo "<td width = '20% ‘>$ classid</td>"; 
echo "<td width= '12% >$ credit </td>"; 
echo "<td width= ‘12% ">< input type = ‘checkbox' name = 'T_id[]' value= '$ id' /></td 
A 
echo "</tr >"; 
}while( $ new_row = mysql_fetch_array( $ new_result)); 
// 开 始 分 页 导航 条 代码 
$ pagenav = ""; 
if( $ prepg) // 如 果 当 前 显示 第 一 页 , 则 不 会 出 现 "上 一 页 " 
$ pagenav. = "<a href = ' $ url?page = $ prepg'> 上 一 页 </a> "; 
for( $i=1;$i<= $pagenum; $ i++)//S pagenum 为 总 页 数 
{ 
if( $ page == $ i) $ pagenav. = "<b>< font color = '#FF0000'> $ i</font ></b> gnbsp; "; 


else $ pagenav. =" <a href = '$ url?page = $ i'>$ i"."gnbsp;</a>"; 
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if( $ nextpg) // 如 果 当 前 显示 最 后 一 页 , 则 不 会 出 现 "下 一 页 " 
$ pagenav. =" <a href = '$ url?page = $ nextpg > 下 一 页 </a>"; 
$ pagenav. = "gnbsp;&nbsp; 共 ". $ pagenum. "页 "; 


// 输 出 分 页 导航 
echo "<tr><tdcolspan= '7'align= 'center'>". $ pagenav. "</td></tr>"; 
} 
else echo "<tr><td colspan = '7'align= 'center > 暂 无 记录 </td></tr>"; 
} 
if(isset( $ _REQUEST[ "add" ])) // 单 击 * 添 加 ”按钮 
{ 
header( "Location:Student_add. php" ); 
} 
?><tr> 


<td colspan = '7'align= 'center'>< input type = 'submit ' name = 'add' value = ' 添 加 ' /> &nbsp; 
gnbsp; Snbsp; Snbsp;< input type = 'submit' name = 'del' value = ' 删 除 ' onClick = "delcfm()" /> </td 
> 

</tr> 

</table> 

</div> 

</form> 

</body > 


2. Student_add. php 学 生 添 加 页 面 


使 用 PHP 脚本 验证 表单 数据 , 当 添加 一 位 学 生 时 , 先 检查 学 生 表 是 否 存在 该 学 号 ,如 
果 该 学 号 已 存在 , 则 提示 重 输 。 运 行 界面 如 图 10-10 所 示 。 


















































图 10-10 学 生 添加 页 面 


相关 代码 如 下 : 

< head> 

<meta http— equiv = "Content - Type" content = "text/html; charset =utf -8" /> 
<title> 学 生 添 加 </title> 


< script src = "../scripts/Com. js"></script > 
< style type = "text/css"> 
<! 











.STYLE1 {color: 井 FFE0000} 
#table2 { 
width: 500px; 
margin: 0 auto; 


body, td, th { 
font ~ size: 14px; 
} 
-—> 
</style> 
<div style = 'Display:none '> 
<?php 
include "../Fun. php"; // 选 择 数 据 库 
include "../IsLogin. php"; // 判 断 用 户 是 否 登 录 
?> 
</div> 
</head> 
<body> 
<?php 
if (isset( $ _REQUEST[ "add" ])) 
{ 
$ test =1; // 只 要 $ test = 0, 表单 信息 就 无 法 提交 
$ studentid = $ _REQUEST["studentid" ] ; 
$ studentname = $ _REQUEST["studentname" ]; 
$ pnd = $ _REQUEST[ "pwd" ]; 
$ sex = @ $ _REQUEST[ "sex" ]; // 若 未 选中 任何 选项 , sex 就 不 存在 
$ birthday = $ _REQUEST["birthday" ]; 
$ classid = $ _REQUEST[ "classid" ]; // 取 得 班级 序号 
$credit = $ _REQUEST["credit" ]; 
// 若 正则 表达 式 含 ^、$ ,只 有 正则 表达 式 与 字符 串 完全 匹配 ,该 函数 才 返 回 1 
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$ checkbirthday = preg_match( '/*\d{4} - (0?\d|1?[012])— (0?\d| [12]\d|3[01]) $/°, 


$ birthday) ; 
if( $ studentid =="") {$ studentidl = "必须 输入 学 号 !"; $ test = 0;} 
elseif(preg_match( '/^\d{10} $/', $ studentid) == 0) 
{ $ studentidl = "学 号 必须 为 10 位 数字 !"; $ test = 0;} 
else { 5$ sql ="select * from student where studentid= '$ studentid’"; 
$ result =mysql_query( $ sql); 
if (mysql_num_rows( $ result)>= 1) 


{ $ studentidl = "输入 的 学 号 已 经 存在 ,请 重 输 !"; $ test = 0;} 


} 
if ( $ studentname == "") { $ studentnamel = "必须 输入 姓名 !"; $ test = 0;} 
if ($ pwd=="") {$ pwdl = "必须 输入 密码 !"; $ test = 0;} 
if ($ sex= ) {$ sexl = "必须 选择 性 别 !"; $ test = 0;} 





证 ($birthday== "") { $birthdayl = "必须 输入 日 期 !"; $ test = 0;} 

elseif ( $ checkbirthday == 0) { $ birthdayl = "日 期 必须 为 yyyy 一 mm- dd!"; $ test =0;} 
if ($classid=="") {$classidl = "必须 输入 班级 序号 !"; $ test = 0;} 

if ($ test==1) 


{ if ($credit =="") $ sql = "insert into student (studentid, studentname, pwd, sex, birthday, 
classid) values( ' $ studentid', '$ studentname', ' $ pwd', '$ sex' ' $ birthday', '$ classid’)"; 
else $ sql = "insert into student values( ' $ studentid', ' $ studentname'’, ' $ pwd','$ sex', 
'$ birthday', ' $ classid', $ credit)"; 
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mysql_query( $ sql); 
echo "< script language = 'javascript '> alert( ' 插 入 成 功 ! ');</script >"; 


} 
We 
< table border = "0" cellpadding = "0" cellspacing = "0" width= "100%" id= "tablel"> 
<tr> 
<td> <form action="" method = "post" name= "forml" > 
< table border = "1" cellpadding = "4" cellspacing = "0" width = "500px" id = " table2" 
bordercolor = " #328EBE"> 
<tr> 
<td colspan = "2" align = "center” bgcolor = " 间 328EBE"> 添加 学 生 信 息 </td> 
</tr> 
<tr> 
<tdwidth="25%" align = "center" > 学 号 </td> 
<td width= "75%" align = "left">< input type = "text" name = "studentid" jd = 
"studentid" /> 
<font color = "##FF0000">* </font ><?php echo "<font size = '2'color = 'FF0000'>". 
@ $ studentidl. "</font >";?></td> 
</tr> 
<tr> 
<tdwidth="25%" align= "center"> 姓 名 </td> 
<td width = "75%" align = "left">< input type = "text" name = "studentname" id= 
"studentname" /> 
< font color =" 间 FF0000">* </font ><?php echo "< font size = '2' color = ‘FF0000 '>". 
@ $ studentnamel."</font >";?> 
</td> 
</tr> 
<tr> 
<td width = "25$% " align = "center"> 密 码 </td> 
<tdwidth="75%" align= "left">< input type = "password" ”name = "pwd" size = "24" 
value="" id= "pwd"/> 
< font color = "##FF0000">* </font ><?php echo "< font size= '2' color = 'FF0000 '>". 
@ $ pwdl."</font >";?> </td> 
</tr> 
<tr> 
<tdwidth="25%" align= "center"> 性 别 </td> 
<td width= "75% "align = "left">< input type = "radio" name = "sex" id = "radio" 
value= " 男 ” /> 
男 &nbsp;&nbsp; < input type= "radio" name = "sex" id= "radio2" value= " 女 ”/> 
女 gnbsp;<font color =" 井 FF0000"> * </font > <?php echo "< font size= '2 "color = 
'FF0000 '>". @ 5$ sexl."</font>";?></td> 
</tr> 
<tr> 
<td align = "center"> 出 生日 期 </td> 
<td align = "left">< input type= "text" name = "birthday" jd = "birthday" /> 
< font color = "##FF0000"> * </font ><?php echo "< font size= '2' color= 'FF0000'>". 
@ $ birthdayl. "</font >";?></td> 
</tr> 
<tr> 
<td align = "center"> 班 级 序号 </td> 

















第 10 章 “学 生 学 籍 成 绩 管 理 系统 开发 实例 








" nm 


<td align = "left">< input name = "classid" type = "text" id= "classid" value= "<? 
php if (isset( $ _SESSION["classid"])) echo $ _SESSION[ "classid"]; else echo @ 
$ classid;?>" /> <font color ="#FF0000">* </font ><?php echo "< font size= '2°' 
color = ‘FF0000'>". @ $ classidl. "</font >";?></td> 

</tr> 

这 
<td width = "25$" align= "center"> 总 学 分 </td> 
<td width="75$% "align = "left">< input type = "text" name = "credit" size = "25" 
value= "" id= "credit"/></td> 


</tr><tr> 





井 328EBE"> 
添加 ”/> 
< input type = " reset" name = "back2” value = "返回 ”onclick = " location. href = 
'student. php" /> 
</td> 
</tr> 
</table ></form></td> 
</tr> 
</table> 
</body> 


<tdcolspan= "2" align = "center" bgcolor 






< input type= "submit" name = "add" value = 


3. Student_update. php 学 生 修改 页 面 

首先 接收 从 Student. php 页 面 传送 过 来 的 学 号 ,然后 显示 该 学 生 的 学 号 姓名、 密码 、 性 
别 、 出 生日 期 \ 班 级 序号 和 总 学 分 。 学 号 是 主键 ,不 能 修改 ,但 允许 管理 员 修 改 学 生 的 其 他 
信息 。 


相关 代码 如 下 : 

<head> 

<meta http— equiv = "Content - Type" content = "text/html; charset =utf -8" /> 
<title> 学 生 修 改 </title> 


< script src = "../scripts/Com. js"></script > 
< style type = "text/css"> 
二 二 二 
.STYLE1 {color: 井 FF0000} 
#3table2 { 
width: 500px; 
margin: 0 auto; 





} 
body, td, th { 
font — size: 14px; 
} 
一 一 > 
</style> 
<div style= "Display;ione> 
?php 
include "../Fun. php"; // 选 择 数据 库 
include "../IsLogin. php"; // 判 断 用 户 是 否 登 录 


?> 
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</div> 

</head> 

<body> 

<?php 

$ studentid = $ _REQUEST[ "id" ]; // 学 号 是 主键 ,不 能 修改 
if (isset( $ _REQUEST[ "update"])) 


?> 


{ 


} 


$ test=1; // 只 要 $ test = 0, 表单 信息 就 无 法 提交 

$ studentname = $ _REQUEST["studentname" ]; 

$ pwd = $ _REQUEST[ "pwd" ]; 

$ sex = @ $ _REQUEST[ "sex" ]; // 若 未 选中 任何 选项 , sex 就 不 存在 

$ birthday = $ _REQUEST[ "birthday" ]; 

$ classid = $ _REQUEST[ "classid" ]; // 取 得 班级 序号 

$ credit = $ _REQUEST["credit" ]; 

// 若 正则 表达 式 含 *、$ ,只 有 正则 表达 式 与 字符 串 完全 匹配 ,该 函数 才 返 回 1 

$ checkbirthday = preg_match( '/*\d{4} - (0?\d|1?[012]) - (0?\d|[12]\d|3[01]) $/°, 

$ birthday) ; 

if ( $ studentname == "") { $ studentnamel = "必须 输入 姓名 !"; $ test = 0;} 

if ($ pwd=="") {$ pwdl = "必须 输入 密码 !"; $ test = 0;} 

if ($ sex ) { $ sexl = "必须 选择 性 别 !"; $ test = 0;} 

if ($birthday =="") { $ birthdayl = "必须 输入 日 期 !"; $ test = 0;} 

elseif ( $ checkbirthday == 0) { $ birthdayl = "日 期 必须 为 YYYY 一 mm- dd!"; $ test =0;} 

if ($classid=="") {$classidl =" 必 须 输入 班级 序号 !"; $ test = 0;} 

if ($test==1) 

{ 证 ($credit=="") $sql="update student set studentname = '$ studentname' ,pwd= ' $ pwd’, 
sex= '$ sex',birthday = '$ birthday', classid= ' $ classid' where studentid= '$ studentid'"; 
else $ sql = "update student set studentname = '$ studentname’, pnxd = '$ pwd’, sex = '$ sex', 
birthday = ' $ birthday ', classid = ' $ classid', credit = $ credit where studentid = 
'$ studentid'"; 
mysql_query( $ sql); 
echo "< script language = 'javascript '> alert( ' 修 改 成 功 ! ');</script >"; 

} 









$sql="select * from student where studentid= '$ studentid'"; 
$result =mysql_query( $ sql); 

5$ row = mysql_fetch assoc( $ result); 

$ studentname = $ row["studentname"]; 

$ pwd = $ row[ "pwd" ]; 

$ sex= $ row["sex"]; 

$birthday= $ row[ "birthday"]; 

$classid= $ row[ "classid"]; 

$credit = $ row[ "credit"]; 


< table border = "0" cellpadding = "0" cellspacing = "0" width="100%" id= "tablel"> 
<tr> 


<td> < form action="" method = "post" name= "forml" > 
< table border = "1" cellpadding = "4" cellspacing = "0" width = "500px" id = "table2" 
bordercolor = " #328EBE"> 
<tr> 
<td colspan = "2" align = "center"” bgcolor =" 井 328EBE"> 修改 学 生 信息 </td> 
</tr> 
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<tr> 
<td width = "25 和 "align = "center" > 学 号 </td> 
<td width= "75%" align= "left">< input name = "id" type= "text" id= "id" value = 
"<?php echo $ studentid;?>" readonly = "readonly" /> 
<font color = " 间 FF0000">* </font ><?php echo "<font size= '2'color = 'FF0000'>". 
@ $ studentid1. "</font >";?></td> 
</tr> 
<tr> 
<tdwidth="25%" align= "center"> 姓 名 </td> 
<tdwidth= "75%" align = "left">< input name = "studentname" type = "text" jd = 
"studentname" value = "<?php echo $ studentname; ?>" /> 
< font color ="#FF0000">* </font ><?php echo "< font size = '2' color = 
‘FF0000 '>". @ $ studentnamel. "</font >";?> 








</td> 
</tr> 
<tr> 
<td width = "25$%" align = "center"> 密 码 </td> 
<tdwidth="75%" align = "left">< input type = "password" name = "pwd" value = 








"<?php echo $ pwd; ?>" id= "pwd"/> 
< font color ="#FF0000">* </font ><?php echo "< font size = '2' color = 
‘FF0000 >". @ $ pwdl. "</font >";?> </td> 
</tr> 
<tr> 
<tdwidth="25%" align= "center"> 性 别 </td> 
<td width= "75%" align = "left">< input name = "sex" type = "radio" id = "radio" 
value = " 男 " <?php if ( $ sex==" 男 ") echo "checked";?>/> 
男 snbsp;&nbsp; < input type = "radio" name = "sex" id = "radio2" value =" 女 " <?php 
if ( $ sex== " 女 ") echo "checked" ;?>/> 
女 &nbsp;< font color =" 井 FF0000"> * </font > <?php echo "< font size= '2'color= 
"FF0000 ">". @ $ sexl."</font >";?></td> 
</tr> 
<tr> 
<td align = "center"> 出 生日 期 </td> 
<tdalign= "left">< input type = "text" name = "birthday" id= "birthday" value = 
"<?php echo $ birthday; ?>"/> 
<font color = "#3FF0000">* </font ><?php echo "< font size= '2'color= 
"FF0000 '>". @ $ birthday1. "</font >";?></td> 
</tr> 
<tr> 
<td align = "center"> 班 级 序号 </td> 
<tdalign= "left">< input name = "classid" type = "text" id= "classid" value = 
"<?php echo $ classid; ?>" /> <font color =" 井 FF0000"> * </font ><?php echo "<font 
size = '2' color = 'FF0000 >". @ $ classidl. "</font >";?></td> 
</tr> 
<tr> 
<tdwidth="25%" align = "center"> 总 学 分 </td> 
<tdwidth="75%" align= "left">< input type = "text" name = "credit" size = "25" 
id= "credit" value = "<?php echo $ credit; ?>" /></td> 
</tr> <tr> 
<td colspan= "2" align= "center" bgcolor = "#328EBE"> 
< input type = "submit" name = "update” value = "修改 " id= "update" /> 
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< input type = " reset" name = "back2”value = "返回 "onclick = " location. href = 


'student. php""/> 
</td> 
</tr> 
</table></form></td> 
</tr> 
</table> 
</body> 


10.4.4 课程 设置 管理 
1. Course. php 课程 查询 .删除 页 面 


系统 起 始 仅 显 示 查 询 顶 部 , 当 系统 管理 员 选 择 一 个 专业 ,并 单 击 " 查 询 ” 按 钮 后 ,页 面 才 
会 分 页 显示 查询 结果 。 当 选择 某 些 课 程 , 并 单 击 “删除 "按钮 时 , 即 删除 选中 的 课程 ; 单 击 
“添加 ”按钮 ,显示 记录 添加 页 面 ; 单 击 某 条 记录 的 超 链 接 ,显示 该 记录 的 修改 页 面 。 运 行 界 
面 如 图 10-11 所 示 。 






































请 选择 专业 Y 
计算 机 网 络 技术 专业 课程 设置 
课程 号 课程 名 总 课时 人 学 分 删除 国 
010 人 72 4 加 
012 大 学 生理 雪 到 育 2 0 回 
020 思想 道德 与 法 律 基础 54 3 加 
030 形势 与 政策 40 2 回 
040A ”| ”大 学 闫 滞 () 56 3 | 上 
040B 大 学 英语 (2) 72 4 
050 计算 机 应 用 基础 36 1 加 
0502020C 毕业 设计 168 | 6 
0502040C 网 络 综合 布线 技术 72 4 
05020490 计算 机 英语 36 2 回 
1 2 3 4 5 下 -页 共 5 页 
sm) [ai 




















10-11 课程 查询 页 面 
相关 代码 如 下 : 


<head> 
<meta http - equiv = "Content - Type" content = "text/html; charset = utf- 8" /> 
< link href ="../styles/com. css" rel = "stylesheet" /> 
< style type = "text/css"> 
table { 
width: 70%; 
margin: 0 auto; 
} 
</style> 
<div style = 'Display:none '> 
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<?php 
include "../Fun.php"; // 选 择 数 据 库 
include "../IsLogin. php"; 


?> 
</div> 
< script src = "../scripts/Com. js"></script > 
< script language = " javascript"> 
function checkmajor( ) 
{ 
if (document. forml. major. value == "") 
{ alert(" 请 选择 专业 !"); 
document. form1l. major. focus( ); 
return false; 


} 





</script > 

</head> 

<body> 

< form method = "post" name = "form1"> 
<div align = "center"> 


< font style = "font - family: ' 华 文 新 魏 '; font - size:20px" > 课程 设置 管理 </font ><br /> 

< select name = "major”jid = "major"> 
<option value =""> 请 选择 专业 </option> 
<?php 
$ sqlx= "select distinct majorname from class"; 
$ rs0=mysql_query( $ sqlx); 
$ rowl = mysql_fetch_assoc( $ rs0); 
while( $ rowl) 
{ echo"<option value = '". $ rowl["majorname"]."'>". $ rowl["majorname"]."</option>"; 

$ rowl = mysql_fetch_assoc( $ rs0); 





} 
?> 
</select > gnbsp; < input name = " search” type = " submit” value = "查询 " onclick = " return 
checkmajor()"/> 
<br /> 
<?php 
// 只 有 单 击 “ 查 询 ” 按 钮 或 地 址 栏 page 有 值 , 才 能 显示 记录 
if(isset( $ _REQUEST["search"]) ‖ isset( $ _REQUEST[ "page" ]) ) 
{ 
if(isset( $ _REQUEST[ "search"])) $ _SESSION["major"] = $ _REQUEST[ "major" ]; 
echo $ _SESSION[ "major"]." 专 业 课 程 设置 "; 
} 
?> 
<table> 
<thead> 
<tr> 
<th width = "25 % "> 课程 号 </th> 
<th width = "30 $% "> 课程 名 </th> 
<th width= "15 % "> 总 课时 </th> 
<th width= "15 $% "> 学 分 </th> 
<th width = "15% "> 删除 < input type = 'checkbox' id = 'CBox' onCl ick = 'checkall(this. form) '/> 
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</th> 
</tr> 
</thead > 
<?php 
if(isset( $ _REQUEST[ "del"])) // 单 击 “ 删 除 ” 按 钮 
{ 
$ id= @ $ _REQUEST[ "T_id" ]; //$ id 为 数组 名 
证 (1$ id) echo "< script >alert( ' 请 至 少 选择 一 条 记录 ! ');</script >"; 
else{ 
$ num = count( $ id); // 使 用 count 函数 取得 数组 中 值 的 个 数 
for(S$Si=0;S$Si<Snum;Sir+) // 使 用 for 循环 删除 所 选 数 据 
{ ”// 要 删除 课程 号 为 A 的 记录 ,除非 开课 表 、 成 绩 表 中 没有 课程 号 为 A 的 记录 
$ sql = "select * from offercourse where courseid= '$ id[ $ i]'"; 
$ rsl= mysql_query( $ sql); 
5$ sql = "select * from score where courseid= '$ id[ $i]""; 
$ rs2=mysql_query( $ sql); 
if (mysql_num_rows( $ rsl) == 0 && mysql_num_rows( $ rs2) == 0) 
{ 
$ delsql = "delete from course where courseid= '$ id[ $i]"; 
mysql_query( $ delsql); 
} 
} 
echo "< script >alert( ' 操 作 完 成 ! ');</script >"; 
} 
$ sql = "select * from course where majorname = ‘公共 课 'or majorname= '".$_ 
SESSION[ "major" ]." ' order by courseid"; 
if (!isset( $ _REQUEST[ "page"])) loadinfo( $ sql); 
} 


if(isset( $ _REQUEST[ "search" ]) || isset( $_REQUEST["page"])) 

// 只 有 单 击 “ 查 询 "按钮 或 地 址 栏 page 有 值 ,才能 显示 记录 

{ 
$ sql = "select * from course where majorname = 公共 课 'or majorname = '".$_ 
SESSION[ "major" ]." ' order by courseid"; 
loadinfo( $ sql); 

} 

function loadinfo( $ sqlstr) 

{ 
$ result = mysql_query( $ sqlstr); 
$ total = mysql_num_rows( $ result); 
if (isset( $ _REQUEST["search"])) $ page=1; // 每 次 单 击 “ 查 询 ” 按 钮 ,从 第 1 页 开始 显示 
else $ page = isset( $ _REQUEST[ ‘page'’])?intval( $ _REQUEST[ ‘page']):1; 
// 获 取 地 址 栏 中 page 的 值 , 不 存在 则 设 为 1 


$ num= 15; // 每 页 显示 15 条 记录 

$ url = 'Course. php'; // 本 页 URL 

$ pagenum = ceil( $ total/ $ num) ; ” // 获 得 总 页 数 , ceil() 返 回 不 小 于 x 的 最 小 整数 
$ prepg= $ page— 1; // 上 一 页 


$ nextpg= ( $ page == $ pagenum? 0: $ page+1); // 下 一 页 

//limit m,n: 从 m+1 号 记录 开始 , 共 检索 n 条 

$ new_sql = $ sqlstr." limit ".($ page—1) * $ num.",". $ num;  // 按 每 页 记录 数 生成 查询 语句 
$ new_result = mysql_query( $ new_sql); 
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if( $ new_row= @mysql_fetch array( $ new_result) ) 
{ // 车 有 查询 结果 ,以 表格 形式 输出 

do 

{ 


list( $ id, $ cname, $ period, $ credit) = $ new_row; 
// 数 组 的 键 名 为 从 0 开始 的 连续 整数 
echo "<tr>"; 
echo "< td width = '25 % ><a href = ‘Course_update. php?id= $ id> $ id</a></td>"; 
echo "<td width= '30% '>$ cname </td>"; 
echo "<td width= '15% '>$ period </td>"; 
echo "<td width= '15% '>$ credit </td>"; 
echo "<td width= '15% >< input type= ‘checkbox' name = 'T_id[]'value= '$ id' /> 
</td>"; 
echo "</tr >"; 
}while( $ new_row = mysql_fetch_array( $ new_result)); 
// 开 始 分 页 导航 条 代码 
$ pagenav = ""; 
if( $ prepg) // 如 果 当 前 显示 第 一 页 , 则 不 会 出 现 " 上 一 页 " 
$ pagenav. = "<a href = '$ url?page = $ prepg'> 上 一 页 </a>"; 
for( $i=1;$i<= $ pagenum; $i++)//$ pagenum 为 总 页 数 
if($page == $i) $pagenav. ="< b>< font color = '# FF0000'> $i</font > 
</b> gnbsp; "; 
else $ pagenav. =" <a href = '$ url?page= $ i'>$ i"."gnbsp;</a>"; 
} 
if( $ nextpg) // 如 果 当 前 显示 最 后 一 页 , 则 不 会 出 现 " 下 一 页 " 
$ pagenav. =" <a href = '$ url?page = $ nextpg > 下 一 页 </a>"; 
$ pagenav. = "gnbsp; Snbsp; 共 ". $ pagenum. "页 "; 
// 输 出 分 页 导航 
echo "<tr><td colspan = '5'align= 'center'>". $ pagenav. "</td></tr >"; 


' 
else 
echo "<tr><td colspan = '5'align = 'center > 暂 无 记录 </td></tr>"; 
} 
if(isset( $ _REQUEST[ "add" ])) // 单 击 * 添 加 ”按钮 转向 班级 增加 页 面 
{ 
echo "< script > location. href = ‘Course_add. php ';</script >"; 
} 
?><tr> 
<tdcolspan= "5" align = "center">< input type = 'submit' name = 'add' value = ' 添 
加 '/> gnbsp; gnbsp;&nbsp; gnbsp;< input type = 'submit' name = 'del' value = ' 删 除 ' 
onClick = "delcfm()" /> </td> 
</tr> 
</table> 
</div> 
</form> 
</body> 


2. Course_add. php 课程 添加 页 面 
使 用 PHP 脚本 验证 表单 数据 , 当 添 加 一 门 课程 时 , 先 检查 课程 表 是 否 存 在 该 课程 号 ， 
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10-12 课程 添加 页 面 


相关 代码 如 下 : 


<head> 
<meta http— equiv = "Content - Type" content = "text/html; charset = utf - 8" /> 
<title > 课程 添加 </title > 


< script src = "../scripts/Com. js"></script > 
< style type = "text/css"> 

2 二 

.STYLE1 {color: 井 FF0000} 

#table2 { 


width: 500px; 
margin: 0 auto; 
} 
body, td, th { 
font — size: 14px; 
} 
-一 > 
</style> 
<div style = 'Display:none '> 
<?php 
include "../Fun. php"; // 选 择 数据 库 
include "../IsLogin. php"; // 判 断 用户 是 否 登 录 
er 
</div> 
</head > 
<body> 
<?php 
if (isset( $ _REQUEST[ "add" ])) 
{ 
$ test=1; // 只 要 $ test = 0, 则 表单 信息 就 无 法 提交 
$ courseid = $ _REQUEST["courseid" ]; 
$ coursename = $ _REQUEST["coursename" ]; 
$ period= $ _REQUEST["period" ]; 
$ credit= $ _REQUEST["credit" ]; 
$ majorname = $ _REQUEST[ "majorname" ]; 
// 若 正则 表达 式 含 “、$ ,只 有 正则 表达 式 与 字符 串 完全 匹配 ,该 函数 才 返 回 1 
if( $ courseid=="") {$ courseidl = "必须 输入 课程 号 !"; $ test = 0;} 
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elseif(preg_match( '/^\d{8} $ /', $ courseid) == 0) 
{ $ courseidl = "课程 号 必须 为 8 位 数字 !"; $ test = 0;} 
else { $ sql ="select * from course where courseid= ' $ courseid'"; 
$ result = mysql_query( $ sql); 
if (mysql_num_rows( $ result)>=1) 


{$courseidl = "输入 的 课程 号 已 经 存在 ,请 重 输 !"; $ test = 0;} 


} 
if ( $ coursename =="") { $ coursenamel = "必须 输入 课程 名 !"; $ test = 0;} 
证 ( $ period=="") {$ periodl =" 必 须 输入 学 时 !"; $ test = 0;} 


elseif (preg_match( '/*\d{1,3} $/', $ period) == 0) 











{ $ periodl = "学 时 必须 为 1-3 位 数字 !"; $ test = 0;} 

if ($credit "") {$creditl = "必须 选择 学 分 !"; $ test = 0;} 

if ( $ majorname =="") { $ majornamel = "必须 选择 专业 名 称 或 公共 课 !"; $ test = 0;} 

if ( $ tes 1) 

{ $sql="insert into course values( '$ courseid '，' $ coursename '，$ period, $ credit, 


'$ majorname ’)"; 
mysql_query( $ sql); 
echo "< script language = 'javascript '> alert( ' 插 入 成 功 ! ');</script >"; 


} 
?> 
< table border = "0" cellpadding = "0" cellspacing = "0" width= "100%" id= "tablel"> 
<tr> 
<td><formaction="" method = "post" name = "forml" > 
< table border = "1" cellpadding = "4" cellspacing = "0" width = "500px" id = "table2" 
bordercolor = " #328EBE"> 
<tr> 
<td colspan = "2" align = "center”bgcolor = " 间 328EBE"> 添加 课程 信息 </td> 
</tr> 
EE 
<tdwidth="25% "align= "center" > 课程 号 </td> 
<tdwidth="75%" align = "left">< input type = "text" name = "courseid" id = 


"courseid" /> 
<font color = "FF0000">* </font ><?php echo "<font size= '2'color = 'FF0000'>". 
@ $ courseidl. "</font >";?></td> 
</tr> 
<tr> 
<tdwidth= "25%" align= "center"> 课 程 名 </td> 
<tdwidth="75%" align = "left">< input type = "text" name = "coursename" jd = 
"coursename" /> 
<font color =" 井 FF0000"> * </font ><?php echo "<font size = '2' color = 'FF0000 >".@ 
$ coursenamel. "</font >" ;?> 
</td> 
</tr> 
<tr> 
<tdwidth="25%" align= "center"> 总 课时 </td> 
<td width= "75%" align = "left">< input type = "password" name = "period" size = 
"24" value="" id= "period"/> 
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< font color = "FF0000"> * </font ><?php echo "<font size = '2'color = 'FF0000>".@ 
$ period1. "</font >";?> </td> 
</tr> 
<tr> 
<tdwidth="25%" align= "center"> 学 分 </td> 
<td width = "75 多 "align= "left">< select name= "credit" id = "credit"> 
<option value = ""> 请 选择 学 分 </option> 
<option>1 </option> 
<option>2 </option> 
<option>3</option> 
<option>4</option> 
<option>5 </option> 
<option>6 </option> 
<option>7 </option> 
<option> 8 </option> 
</select > &nbsp;< font color = " 井 FF0000"> * </font > <?php echo "< font size= '2/ 
color = 'FF0000'>". @ 5$ credit1."</font >";?></td> 





</tr> 
<tr> 
<td align = "center"> 专 业 </td> 
<td align = "left">< select name = "majorname" id= "majorname"> 


<option value = ""> 请 选择 专业 </option > 
<?php 

$ sqlx= "select distinct majorname from class"; 

$ rsl = mysql_query( $ sqlx); 

$ rowl = mysql_fetch_assoc( $ rs1); 

while( $ rowl) 

{ echo "<option>". $ rowl["majorname"]."</option>"; 
$ rowl = mysql_fetch_assoc( $ rs1); 


?> 
<option> 公 共 课 </option> 
</select > <font color =" 井 FF0000"> * </font ><?php echo "< font size= '2'color 
‘FF0000 '>". @ $ majornamel. "</font >";?></td> 
</tr> <tr> 
<td colspan = "2" align = "center" bgcolor = "#328EBE"> 
< input type = "submit" name = "add" value = "添加 " /> 
< input type = "reset" name = "back2" value = "返回 "onclick = "location. href 
'course. php'"/> 
</td> 
</tr> 
</table ></form></td> 
</tr> 
</table> 
</body> 


nl 





0 


3. Course_update. php 课程 修改 页 面 
首先 接收 从 Course. php 页 面 传送 过 来 的 课程 号 ,然后 显示 该 课程 的 课程 号 .课程 名 ,总 
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课时 、 学 分 .专业 。 课 程 号 是 主键 ,不 能 修改 ,但 允许 管理 员 修改 课程 的 其 他 信息 。 公 共 课程 
的 课程 号 唯一 ,但 同一 专业 课程 在 不 同 专业 开设 ,具有 不 同 的 课程 号 。 


相关 代码 如 下 : 

<head> 

<meta http — equiv = "Content - Type" content = "text/html; charset = utf - 8" /> 
<title > 课程 修改 </title> 


< script src = "../scripts/Com. js"></script > 
< style type = "text/css"> 


< 一 一 
.STYLE1 {color: 井 FF0000} 
#table2 { 
width: 500px; 
margin: 0 auto; 
. 
body, td, th { 
font ~ size: 14px; 
} 
--> 
</style> 
<div style = 'Display:none '> 
<?php 
include "../Fun. php"; // 选 择 数 据 库 
include "../IsLogin. php"; // 判 断 用 户 是 否 登录 
?> 
</div> 
</head> 
<body> 
<?php 
$ courseid= $_REQUEST[ "id" ]; // 课 程 号 是 主键 ,不 能 修改 


if (isset( $ _REQUEST[ "update"] ) ) 
{ 
$ test=1; // 只 要 $ test = 0, 表 单 信息 就 无 法 提交 
$ coursename = $ _REQUEST["coursename" ]; 
$ period= $ _REQUEST["period" ]; 
$ credit = $ _REQUEST["credit" ]; 
$ majorname = $ _REQUEST[ "majorname" ]; 
// 若 正则 表达 式 含 *、$ ,只 有 正则 表达 式 与 字符 串 完全 匹配 ,该 函数 才 返 回 1 
if ( $ coursename == "") { $ coursenamel = "必须 输入 课程 名 !"; $ test = 0;} 
") { $ periodl = "必须 输入 学 时 !"; $ test = 0;} 
elseif (preg_match( '/*\d{1,3} $/', $ period) == 0) 
{ $ periodl = "学 时 必须 为 1-3 位 数字 !"; $ test = 0;} 
if ($credit =="") {$creditl = "必须 选择 学 分 !"; $ test = 0;} 
if ( $ majorname == "") { $ majornamel = "必须 选择 专业 名 称 或 公共 课 !"; $ test = 0;} 
if ($test==1) 
{ $ sql ="update course set coursename = ' $ coursename '，period = $ period, credit = 





$ credit where courseid= '$ courseid'"; 
mysql_query( $ sql); 
echo "< script language = 'javascript '> alert( ' 修 改 成 功 ! ');</script >"; 
} 
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} 

$sql="select * from course where courseid= ' $ courseid'"; 
$result =mysql_query( $ sql); 

$ row = mysql_fetch assoc( $ result); 

$ coursename = $ row["coursename"]; 

$ period = $ row[ "period"]; 

$credit = $ row[ "credit"]; 

$ majorname = $ row[ "majorname" ]; 


?> 
< table border = "0" cellpadding = "0" cellspacing = "0" width="100%" id= "tablel"> 
<tr> 
<td> <form action="" method = "post" name = "forml" > 


< table border = "1" cellpadding = "4" cellspacing = "0" width = "500px" id = "table2" 


bordercolor = " #328EBE"> 
<tr> 
<td colspan=" 
</tr> 
<tr> 
<td width = "25$%" align= "center" > 课程 号 </td> 





align = "center”bgcolor = " 井 328EBE"> 修 改 课程 信息 </td> 


<td width= "75$% "align= "left">< input name = "id" type= "text" id= "id" value = 
"<?php echo $ courseid; ?>" size = "28" readonly= "readonly" /></td> 





</tr> 
<tr> 
<td width = "25% "align= "center"> 课 程 名 </td> 
< td width 5%" align ="left">< input name = "coursename" type = "text" jd 





"coursename" value = "<?php echo $ coursename; ?>" size= "28 "/> 
< font color = "##FF0000"> * </font ><?php echo "< font size = '2'color = 'FF0000>".@ 


$ coursenamel. "</font >";?> 
</td> 
</tr> 
<tr> 
<tdwidth="25%" align= "center"> 总 课时 </td> 


<tdwidth="75%" align= "left">< input type = "text" name = "period" size= "28" 


value = "<?php echo $ period; ?>" id= "period"/> 


< font color =" 井 FF0000"> * </font ><?php echo "<font size = '2' color = 'FF0000 >".@ 


$ period1."</font >";?> </td> 
</tr> 
<tr> 


<td width = "25%" align= "center"> 学 分 </td> 





<tdwidth="75%" align= "left">< select name = "credit" id= "credit"> 


<option value = ""> 请 选择 学 分 </option> 
< option <?php if ( $ credii 
< option <?php if ( $ credii 
< option <?php if ( $ credii 
< option <?php if ( $ credi 
< option <?php if ( $ credii 
< option <?php if ( $ credi 
< option <?php if ( $ credii 
< option <?php if ( $ credil 














) echo "selected" ?>>1</option> 
2) echo "selected" ?>>2 </option> 
3) echo "selected" ?>>3 </option > 
4) echo "selected" ?>> 4 </option> 
) echo "selected" ?>>5 </option> 
) echo "selected" ?>>6 </option> 
7) echo "selected" ?>>7 </option> 
8) echo "selected" ?>> 8 </option> 


</select > &nbsp;< font color = "#3FF0000">* </font > <?php echo "< font size= '2° 


color = 'FF0000'>". @ $ credit1. "</font >";?></td> 
</tr> 
<tr> 

<tdalign="center"> 专 业 </td> 
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<td align = "left">< select name = "majorname" id= "majorname"> 
<option value = ""> 请 选择 专业 </option> 
<?php 

$ sqlx= "select distinct majorname from class"; 

$ rsl= mysql_query( $ sqlx); 

$ rowl = mysql_fetch_assoc( $ rs1); 

while( $ rowl) 

{ if ($majorname == $rowl["majorname"]) echo "< option selected >". $ rowl 
["majorname" ]. "</option >"; else echo "< option>". $ rowl[ "majorname"]. "</option >"; 
$ rowl = mysql_fetch_assoc( $ rs1); 

’ 

?> 
< option <?php if ( $ majorname == "公共 课 ") echo "selected" ?>> 公 共 课 </option> 
</select > <font color = " 井 FFE0000"> * </font ><?php echo "< font size= '2'color= 
'FE0000 '>". @ $ majornamel. "</font >";?></td> 
</tr> <tr> 





align = "center" bgcolor = " 井 328EBE"> 
"submit"” name = "update" value = "修改 " id = "update" /> 
reset" name = "back2" value = "返回 "onclick = "location. href = 








< input type 
'course. php'"/> 
</td> 
</tr> 
</table ></form></td> 
</tr> 
</table> 
</body > 


10.4.5 开课 表 管 理 


1. Offercourse. php 开课 表 查 询 .删除 页 面 

系统 起 始 仅 显示 查询 顶部 , 当 系 统管 理 员 选择 一 个 专业 和 一 个 学 期 ,并 单 击 “ 查 询 ” 按 钮 
后 ,页 面 才 会 分 页 显示 指定 专业 的 全 部 班级 在 指定 学 期 的 开课 信息 。 选 择 某 些 记 录 , 并 单 击 
“删除 ”按钮 , 即 删除 选中 的 记录 ; 单 击 “ 添 加 ”按钮 ,显示 记录 添加 页 面 ; 单 击 某 条 记录 的 超 
链接 ,显示 该 记录 的 修改 页 面 。 运 行 界面 如 图 10-13 所 示 。 



























































请 选择 专业 国 | 记 ssS3 则 圈 [去 
2016-2017(2) 学 其 计算 机 网 络 技术 专业 各 班 开课 表 
天 天 名 村 课程 号 课程 名 周 课时 周 数 。 接 溢 范 策 “一 除 
2015 计 算 机 网 络 技 术 1 班 05020490 计算 机 英语 2 | 180 陈 汉 忠 口 
| 
2015 计 算 机 网络 技术 1 | 05022708 | HR 4 | 180 | WE | 口 
2015 计 算 机 网 络 技术 ] 班 | 05028018 | 。 网 络 互 联 技术 | 4 | 180 | 王 兰 | 口 
2015 计 算 机 网 络 技术 ] 班 | 05022318 | java 程 序 设计 (* 课 | 4 | 180 | 村 | 口 
程 设计 ) | 
2015 计 算 机 网 络 技术 ] 班 | 05020808 |AutoCad (+ 考证 ) | 4 | 180 | 地 号 | 口 
2015 计 算 机 网 络 技术 ] 班 | 0502050C | 。 PHP 课 得 设计 2 | 180 | kx 忠 | 口 
2015 计 算 机 网 络 技术 ] 班 | 05027308 | 。 网 络 安全 技术 | 4 | 180 | 加 如 | 口 
2015 计 算 机 网 络 技 术 1 班 | 0502040C 网 络 综合 布线 技术 4 | 180 李 震 口 
1 2 下 一 页 共 7 页 
Er] es] 
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相关 代码 如 下 : 


<head> 

<meta http— equiv = "Content — Type" content = "text/html; charset =utf -8" /> 
< link href ="../styles/com. css" rel = "stylesheet" /> 

< script src ="../scripts/Com. js"></script > 





<style type = "text/css"> 
table { 
width: 90%; 
margin: 0 auto; 
} 
</style> 
<title > 开课 信 息 </title> 
</head> 
<body> 
<div style = "Display:none"> 
<?php 
include "../Fun. php"; 
include "../IsLogin. php"; 
是 
</div> 


< script type = "text/javascript"> 
function check( ) 
if (document. form]l. major. value == "") 
| 
alert(" 请 选择 专业 !"); 
document. forml. major. focus( ); 
return false; 
} 
if (document. form1l. term. value = 
{ 
alert(" 请 选择 学 期 !"); 


document. forml. term. focus( ); 





return false; 


} 
</script > 
< form method= "post" name = "forml"> 
< div align = "center"> 
< font style = "font - family: ' 华 文 新 魏 '; font - size:20px" > 开课 表 管 理 </font ><br> 
< select name = "major" id= "major"> 
<option value = ""> 请 选择 专业 </option > 
<?php 
$ sqlx= "select distinct majorname from class"; 
$ rsl=mysql_query( $ sqlx); 
$ rowl = mysql_fetch_assoc( $ rs1); 
while( $ rowl) 
{ 
echo "<option value= ". $ rowl["majorname"].">". $ rowl["majorname"]."</option>"; 
$ rowl =mysql_fetch_assoc( $ rs1); 








?> 
</select> 
< select name = "term"> 
<option value =""> 请 选择 学 期 </option > 
<?php 
$ array = getdate( ); 
$ year = $ array["year"]; 
$ month= $array["mon"]; 
if ($month<=7) for( $i=0;$i<3;$i++) 
{ echo"<option value= '".($ year— $i-1)."—-".($year- $i)."(2)'>" 
.($year— $i-1)."—".($year- $i)."(2)</option>"; 
echo "<option value= '".( $year— $i-1)."—".($year- $i)."(1)>" 
“($year- $i-1)."-".($year- $i)."(1)</option>"; 
} 
else for( $i=0; $i<3;$ i++) 
{ echo "<option value= '".($year—- $i)."—".($year—- $i+1)."(1)'>" 
($year— $i)."—".($year— $i+1)."(1)</option>"; 
echo "<option value= '". ($year— $i-1)."-".($year- $i)."(2)'>" 
($year- $i-1)."—".($year- $1i)."(2)</option>"; 
} 
?> 
</select > gnbsp; 
< input name = "search" type = "submit" value = "查询 " onclick = "return check()"/> 
<br /> <?php // 只 有 单 击 “ 查 询 " 按 钮 或 地 址 栏 page 有 值 ,才能 显示 记录 
if(isset( $ _REQUEST[ "search" ]) || isset( $ _REQUEST[ "page"])) 
{ if(isset( $ _REQUEST["search"])) 
{ $_SESSION["major"] = $_REQUEST[ "major"]; 
$ _SESSION[ "offerterm"] = $ _REQUEST[ "term" ]; 








} 
echo $ _SESSION[ "offerterm" ]. "学 期 &nbsp;&nbsp;". $ _SESSION[ "major"]." 专 业 各 班 开 课表 "; 
} 
?> 
<table> 
<thead> 
<tr> 
<th width= "25$% "align = "center"> 班 级 名 称 </th> 
<thwidth="15%" alig center"> 课 程 号 </th> 
<th width="20%" align = "center"> 课 程 名 </th> 
<th width="10%" align = "center"> 周 课时 </th> 
<th width= "10$% "align = "center"> 周 数 </th> 
<th width="10$% "align = "center"> 授 课 教师 </th> 
<thwidth= "10%" align = "center"> 删 除 < input type = 'checkbox' id = 'CBox 
‘onClick = 'checkall(this. form) '/></th> 
</tr> 
</thead> 
<?php 
if(isset( $_REQUEST[ "del"]) ) // 单 击 * 删 除 "按钮 ,删除 所 选 数据 并 重新 加 载 数 据 
{ 
$ id= @ $ _REQUEST[ "T_id"]; //$ id 为 数组 名 , 每 个 元 素 为 : $ classid- $ courseid 


诗 (1 $ id) echo "< script >alert( ' 请 至 少 选择 一 条 记录 ! ');</script >"; 
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else{ 
foreach( $ idas $x) //$ x 的 格式 为 '$ classid- $ courseid 
{ $ch=explode("—", $x); // 使 用 " - ", 将 $x 分 为 若干 个 子 串 ,并 存 人 数组 中 
$ delsql = "delete from offercourse where classid= '". $ ch[0]." 'and courseid= 
.$chl1]."""; 
mysql_query( $ delsql); 
} 
echo "< script >alert( ' 删 除 成 功 ! ');</script >"; 
} 
$ sql = "SELECT distinct class. classid, enrollyear, class. majorname, classname, course. 
courseid, coursename, weekhour, weeknum, teachername FROM offercourse, course, class, 
teacher WHERE offercourse. courseid = course. courseid and offercourse. classid = class. 


classid and teacher. teacherid = offercourse. teacherid and offerterm = '". $ _SESSION[" 
offerterm"]." ' and class. majorname = '". $ _SESSION[ "major"]." ' order by class. 
classid"; 

if (!isset( $ _REQUEST[ "page"])) loadinfo( $ sql); 

} 


if(isset( $ _REQUEST["search"]) || isset( $ _REQUEST["page"])) 

// 只 有 单 击 “ 查 询 " 按 钮 或 地 址 栏 page 有 值 , 才能 显示 记录 

{ 
$ sql = "SELECT distinct class. classid, enrollyear, class. majorname, classname, 
Course. courseid, coursename, weekhour, weeknum, teachername FROM offercourse, course, 
class, teacher WHERE offercourse. courseid = course. courseid and offercourse. 
classid = class. classid and teacher. teacherid = offercourse. teacherid and 
offerterm= '". $ _SESSION[ "offerterm"]." ' and class. majorname = '". $ _SESSION 
["major"]."'order by class. classid"; loadinfo( $ sql); 

} 

function loadinfo( $ sqlstr) 

{ 

$ result = mysql_query( $ sqlstr); 

$ total = mysql_num_rows( $ result); 

if (isset( $ _REQUEST["search"])) $ page=1; // 每 次 单 击 “ 查 询 " 按 钮 ,从 第 1 页 开始 显示 

else $ page = isset( $ _REQUEST[ 'page'])?intval( $ _REQUEST[ 'page']) :1; 

// 获 取 地 址 栏 中 page 的 值 , 不 存在 则 设 为 1 


$ num = 10; // 每 页 显示 10 条 记录 

$ url = 'Offercourse. php'; // 本 页 URL 

$ pagenum = ceil( $ total/ $ num) ; ”// 获 得 总 页 数 ,ceil() 返 回 不 小 于 x 的 最 小 整数 
$ prepg= $ page—1; = 


$ nextpg= ( $ page == $ pagenum? 0: $ page+1); // 下 一 页 

//limit m,n: 从 m+ 1 号 记录 开始 , 共 检 索 n 条 

$new_sql= $ sqlstr." limit ".($ page—1) * $ num.",". $num;  // 按 每 页 记录 数 生成 查询 语句 

$ new_result = mysql_query( $ new_sql); 

if( $ new_row = @mysql_fetch array( $ new_result)) 

// 数 组 $ new_row 的 键 名 可 为 整数 或 字段 名 

{  // 若 有 查询 结果 ,以 表格 形式 输出 

do 

list( $ classid, $ enrollyear, $ majorname, $ classname, $ courseid, $ coursename, 
$ weekhour, $ weeknum, $ teachername) = $ new_row; 
// 数 组 的 键 名 为 从 0 开始 的 连续 整数 
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echo "<tr>"; 
echo "<td width= '25% '>". $ enrollyear. $ majorname. $ classname. "</td>"; 
echo "<td width= '15% ‘><a href = ‘Offercourse_update. php? 
classid= $ classidgcourseid= $ courseid’>$ courseid</a></td>"; 
echo "<td width= '20% ‘>$ coursename </td>"; 
echo "<td width= '10% '>$ weekhour </td>"; 
echo "<td width= '10% '>$ weeknum </td>"; 
echo "<td width= '10% '>$ teachername </td>"; 
echo "< td width= '10% >< input type = 'checkbox' name = 'T_id[]'value= '$ classid 
— $ courseid' /></td>"; 
echo "</tr >"; 
}while( $ new_row = mysql_fetch_array( $ new_result)); 
// 开 始 分 页 导航 条 代码 
$ pagenav = ""; 
if( $ prepg) // 如 果 当 前 显示 第 一 页 , 则 不 会 出 现 " 上 一 页 " 
$ pagenav. = "<a href = '$ url?page = $ prepg'> 上 一 页 </a>"; 
for( $i=1;$i<= $ pagenum; $i++)//$ pagenum 为 总 页 数 
{ if( $ page == $i) $ pagenav. ="<b>< font color = '##FF0000'> $ i</font ></b> gnbsp;"; 
else $ pagenav. =" <a href = '$ url?page= $ i'>$ i"."gnbsp;</a>"; 
} 
if( $ nextpg)// 如 果 当 前 显示 最 后 一 页 , 则 不 会 出 现 " 下 一 页 " 
$ pagenav. =" <a href = '$ url?page = $ nextpg '> 下 一 页 </a>"; 
$ pagenav. = "gnbsp; &nbsp; 共 ". $ pagenum. "页 "; 
// 输 出 分 页 导航 
echo "<tr><td colspan = '7'align= 'center'>". $ pagenav."</td></tr >"; 


} 
else echo "<tr><td colspan= '7'align= 'center > 暂 无 记录 </td></tr>"; 
} 
if(isset( $ _REQUEST[ "add" ])) // 单 击 “ 添 加 ”按钮 
{ 
header( "Location:Offercourse_add. php" ); 
} 
?> 
<tr> 
<td colspan= '7'align= "center">< input type = 'submit ' name = 'add' value = ' 添 加 ' /> 
&nbsp;S&nbsp;&nbsp;&nbsp;< input type = 'submit ' name = 'del' value = ' 删 除 ' onClick = 
"delcfm()" /> </td> 
</tr> 
</table> 
</div> 
</form> 
</body> 


2. Offercourse_add. php 开课 表 添 加 页 面 

管理 员 选 择 一 个 班级 序号 ,就 能 在 下 拉 框 中 级 联 出 该 班级 所 开设 的 全 部 课程 ,该 下 拉 框 
的 选项 文本 是 课程 名 称 ,value 值 是 课程 号 。 向 一 个 班级 添加 一 门 课程 , 先 检查 开课 表 是 否 
存在 此 班级 序号 和 课程 号 的 记录 ,如 果 此 班级 序号 和 课程 号 已 存在 , 则 提示 重 选课 程 。 运 行 
界面 如 图 10-14 所 示 。 
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图 10-14 开课 表 添加 页 面 


相关 代码 如 下 : 


<head> 
<meta http— equiv = "Content - Type" content = "text/html; charset = utf - 8" /> 
<title> 开 课表 录 人 </title> 
<script src="../scripts/Com. js"></script > 
< style type = "text/css"> 
Ss 
.STYLE1 {color: 间 FF0000} 
#table2 { 
width: 500px; 
margin: 0 auto; 
| 
body, td, th { 
font ~ size: 14px; 
} 
--> 
</style> 
<div style = 'Display:none '> 
<?php 
include "../Fun. php"; // 选 择 数据 库 
include "../IsLogin.php"; // 判 断 用 户 是 否 登 录 
?> 
</div> 
< Script type = "text/javascript"> 
// 选 择 班级 序号 改变 课程 
function change( ) 
{ 


Var kcs = document. forml .classid. value; 


if (kcs =="") {window.alert(" 班 级 序号 不 能 为 空 ") ;document. forml.classid. focus();} 
var kc= kcs. split("|1"); // 按 "1" 将 kcs 分 成 若干 子 串 ,并 依次 存 人 数组 中 ,kc 长 度 为 "| "的 个 


数 +1 


for(i=0;i<(kc. length 一 1)/2;i++) //courseid 的 value 值 为 课程 号 , text 值 为 课程 名 


{ with(document. forml.courseid) 
{ length = (kc.length- 1)/2+1; // 原 有 一 个 选项 
options[i+1].value = kc[2*i]; 
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options[i+1].text =kc[2*i+1]; 


} 
</script > 
</head > 
<body> 
<?php 
if (isset( $ _REQUEST[ "add" ])) 
{ 
$ test=1; // 只 要 $ test = 0, 表 单 信息 就 无 法 提交 
$ id = explode("|", $ _REQUEST["classid"]); 
// 使 用 "| ", 将 字符 串 分 为 若干 个 子 串 , 并 存 人 数组 中 
foreach( $ id as $x) $classid= $x; 
$ courseid = $ _REQUEST["courseid" ]; 
$ weekhour = $ _REQUEST["weekhour" ]; 
$ weeknum = $ _REQUEST[ "weeknum" ]; 
$ offerterm = $ _REQUEST["offerterm" ]; 
$ teacherid = $ _REQUEST[ "teacherid" ]; 
// 若 正则 表达 式 含 、$ ,只 有 正则 表达 式 与 字符 串 完全 匹配 ,该 函数 才 返 回 1 
) {$classidl = "必须 选择 班级 序号 !"; $ test = 0;} 
") { $ courseidl = "必须 选择 课程 名 称 !" ; $ test = 0;} 





if ( $ courseid== 
if ($test==1) 
{ $sql="select * from offercourse where classid= '$ classid' and courseid = '$ courseid’"; 
$ result = mysql_query( $ sql); 
if (mysql_num_rows( $ result)>= 1) 
{$courseidl = "选择 的 课程 名 称 已 经 存在 ,请 重 选 !"; $ test = 0;} 
} 
if ( $ weekhour =="") { $ weekhourl = "必须 输入 周 课时 !"; $ test = 0;} 
elseif(preg_match( '/^\d{1,2} $ /', $ weekhour) ==0) 
{ $ weekhour1l=" 周 课时 必须 为 整数 !"; $ test = 0;} 
if ( $ weeknum== "") { $ weeknuml = "必须 输入 周 数 !1"; $ test = 0;} 
elseif(preg_match( '/*\d+ (\.\d)? $/', $ weeknum) ==0) 
{ $ weeknuml = " 周 数 只 能 整数 或 保留 一 位 小 数 !"; $ test = 0;} 
if ( $ offerterm=="") { $ offerterml = "必须 选择 开设 学 期 !"; $ test = 0;} 
if ($ test==1) 
{ $sql="insert into offercourse values('$ classid', '$ courseid', $ weekhour, 
$ weeknum, ' $ offerterm’', ' $ teacherid')"; 
mysql_query( $ sql); 
echo "< script language = 'javascript '> alert( ' 插 入 成 功 ! ') ;</script >"; 
} 
} 
?> 
< table border = "0" cellpadding = "0" cellspacing = "0" width="100%" id= "tablel"> 
<tr> 
<td> < form action="" method = "post" name= "forml" > 
< table border = "1" cellpadding = "4" cellspacing = "0" width = "500px" id = "table2" 
bordercolor = " #328EBE"> 
<tr> 
<td colspan = "2" align = "center" bgcolor = " 井 328EBE"> 录 和 人 开课 表 </td> 
tr 
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<tr> 
<td width = "25$ "align = "center" > 班级 序号 </td> 
<td width="75%" align= "left">< select name = "classid" id = "classid" onChange = 
"change( ) "> 
<option value = ""> 请 选择 班级 序号 </option > 


<?php 
// 在 php 脚本 中 肉 入 JavasCript 语句 
$ sqlx= "select * from class order by classid"; 
$ rsl=mysql_query( $ sqlx); 
$ rowl = mysql_fetch_assoc( $ rs1); 
// 每 取出 一 个 班级 序号 ,就 查看 其 专业 , 并 输出 其 全 部 课程 
while( $ rowl) 
{ $zy= $rowl["majorname"]; 
$ sqlx= "select distinct courseid, coursename from course where majorname = ' $2y' or 
majorname = ' 公 共 课 '"; 
$ rs2= mysql_query( $ sqlx); 
$ row2 = mysql_fetch_assoc( $ rs2); 
$ course= ""; 
while( $ row2) 
{ 





$ course. = $ row2["courseid"]."|". $ row2["coursename"]."|"; 

$ row2 = mysql_fetch_assoc( $ rs2); 
echo "< option value = '". $ course. $ rowl ["classid"]." ‘>". $ rowl [ "classid"]. 
"</option>"; 
$ rowl = mysql_fetch_assoc( $ rs1); 


?> 
</select > 
< font color = "FF0000">* </font ><?php echo "< font size = '2' color= ‘FF0000'>".@ 
$ classidl. "</font >";?> 





<td width= 
<option value = ""> 请 选择 课程 </option> 
</select> 
< font color = " 井 FF0000"> * </font ><?php echo "< font size= '2'color = 'FF0000">". 
@ 5$ courseid1. "</font >";?> 
</td> 
</tr> 
<tr> 
<tdwidth="25%" align= "center" > 周 课时 </td> 
<td width="75%" align = "left">< input type = "text" name = "weekhour" size= "20" 
value= "" id= "weekhour"/> 
<font color = "##FF0000">* </font ><?php echo "<font size= '2'color= ‘FF0000>". 
@ $ weekhourl. "</font >";?> </td> 
</tr> 
<tr> 
<td width= "25 "align= "center"> 周 数 </td> 
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< td width = "75%" align = "left">< input name = "weeknum" type = "text" jd = 
"weeknum" size= "20" /><font color="##FF0000">* </font ><?php echo "< font size= 
‘2' color = 'FF0000 >". @ $ weeknuml. "</font >";?></td> 

</tr> 


<tr> 
<td align = "center" > 开课 学 期 </td> 
<td align = "left">< select name = "offerterm" id= "offerterm"> 
<option value =""> 请 选择 学 期 </option> 
<?php 
$ array = getdate( ); 
$ year = $ array[ "year" ]; 
$month= $ array[ "mon" ]; 
if ( $month<=7) for( $i=0;$i<3;$i++) 
E 
echo "<option>".($ year— $i-1)."—".($year- $i)."(2)</option>"; 
echo "<option>".($ year— $i-1)."-".($year- $i)."(1)</option>"; 
} 
else for($i=0;$i<3;$it+) 
| 
echo "<option>".($ year— $Si)."-".($year- $i+1)."(1)</option>"; 
echo "<option>".($ year— $i-1)."—".($year- $i)."(2)</option>"; 


?> 
</select > 
< font color = " 间 FF0000">* </font ><?php echo "< font size= '2'color = 'FF0000>".@ 
$ offerterml. "</font >";?></td> 
</tr> 
<tr> 
<tdwidth="25%" align = "center"> 任 课 教师 </td> 
<tdwidth="75%" align= "left">< select name = "teacherid" id= "teacherid"> 
<option value = ""> 请 选择 教师 </option> 
<?php 
$ sql = "select * from teacher order by teacherid, teachername"; 
$ rsl=mysql_query( $ sql); 
$ rowl = mysql_fetch assoc( $ rs1); 
while( $ rowl) 
{ echo "<option value= '". $ rowl["teacherid"]."'>". $ rowl["teacherid"]." 
". $ rowl["teachername"]."</option >"; 
$ rowl = mysql_fetch assoc( $ rs1); 


} 
?> 
</select ></td> 
</tr> <tr> 


<td colspan = "2" align = "center" bgcolor = " 井 328EBE"> 
<input type= add" value = "添加 " /> 
<input type= back2”value = "返回 "onclick = "location. href = 





"submit" name 





reset" name = 
"Offercourse. php'"/> 
</td> 
</tr> 
</table></form></td> 
</tr> 
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</table> 

</body> 

3. Offercourse_update. php 开课 表 修 改 页 面 

首先 接收 从 Offercourse. php 页 面 传送 过 来 的 班级 序号 .课程 号 ,然后 显示 该 课程 的 班 
级 序号 .课程 名 称 、 周 课时 、 周 数 、 开 课 学 期 和 任课 教师 。 班 级 序号 和 课程 号 是 主键 ,不 能 修 
改 , 但 允许 管理 员 修改 课程 的 周 课时 、 周 数 、 开 课 学 期 和 任课 教师 。 


相关 代码 如 下 : 

<head> 

<meta http— equiv = "Content - Type" content = "text/html; charset =utf -8" /> 
<title> 开 课表 修改 </title> 


< Script src = "../scripts/Com. js"></script > 
< style type = "text/css"> 


可 
.STYLE1 {color: 井 FF0000} 
井 table2 { 
width: 500px; 
margin: 0 auto; 
} 
body, td, th { 
font ~ size: 14px; 
} 
-一 > 
</style> 
<div style = 'Display:none '> 
<?php 
include "../Fun. php"; // 选 择 数 据 库 
include "../IsLogin. php"; // 判 断 用 户 是 否 登 录 
> 
</div> 
</head> 
<body> 
<?php 


$ classid= $_REQUEST[ "classid" ]; // 班 级 序号 、 课 程 号 是 主键 ,不 能 修改 
$ courseid= $ _REQUEST[ "courseid" ]; 
if (isset( $ _REQUEST[ "update"])) 
{ 
$ test=1; // 只 要 $ test = 0, 表 单 信息 就 无 法 提交 
$ weekhour = $_REQUEST["weekhour"] ; 
$ weeknum = $ _REOUEST["weeknum" ]; 
$ offerterm = $ _REQUEST["offerterm" ]; 
$ teacherid = $ _REQUEST[ "teacherid" ]; 
// 若 正则 表达 式 含 、$ ,只 有 正则 表达 式 与 字符 串 完 全 匹配 ,该 函数 才 返 回 1 
if ( $ weekhour == "") { $ weekhourl = "必须 输入 周 课时 !"; $ test = 0;} 
elseif(preg_match( '/^\d{1,2} $ /', $ weekhour) == 0) 
{ $ weekhourl = " 周 课时 必须 为 整数 !"; $ test = 0;} 
证 ($ weeknum =="") { $ weeknuml = "必须 输入 周 数 !"; $ test = 0;} 
elseif(preg_match( '/^\d+ (\.\d)? $/', $ weeknum) == 0) 
{ $ weeknuml = " 周 数 只 能 整数 或 保留 一 位 小 数 !"; $ test = 0;} 
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if ( $ offerterm== "") {$ offerterml = "必须 选择 开设 学 期 !"; $ test = 0;} 

if ($ test==1) 

{ $sql= "update offercourse set weekhour = $ weekhour, weeknum = $ weeknum,offerterm= 
'$ offerterm', teacherid = ' $ teacherid ' where classid= '$classid'and courseid= 
'$ courseid'"; 
mysql_query( $ sql); 
echo "< script language = 'javascript '> alert( ' 删 除 成 功 ! ') ;</script >"; 


$ sql = "select * from offercourse where classid= '$ classid'and courseid= '$ courseid'"; 
$ result = mysql_query( $ sql); 
$ row= mysql_fetch_assoc( $ result); 
$ weekhour = $ row["weekhour" ]; 
$ weeknum = $ row["weeknum" ]; 
$ offerterm= $ row["offerterm"]; 
$ teacherid= $ row["teacherid"]; 
?> 
< table border = 
<tr> 
<td> < form action ="”method = "post" name= "forml" > 
< table border = "1" cellpadding = "4" cellspacing = "0" width = "S500px" id = "table2" 
bordercolor = " #328EBE"> 
<tr> 
<td colspan = "2" align = "center" bgcolor = " 间 328EBE"> 修改 开课 表 </td> 
</tr> 
<tr> 
<td width = "25$% "align = "center" > 班级 序号 </td> 
<tdwidth="75%" align = "left">< input name = "classid" type = "text" id= 
"classid" value = "<?php echo $ classid;?>" readonly= "readonly" /></td> 
</tr> 
<tr> 
<tdwidth="25%" align = "center"> 课 程 名 称 </td> 
<tdwidth="75%" align = "left">< input name = "courseid" type = "text”jd = 
value = "<?php echo $ courseid;?>" readonly= "readonly" /></td> 





0" cellpadding = "0" cellspacing = "0" width= "100%" id= "tablel"> 










站 





<tr> 
<td width = "25%" align = "center" > 周 课时 </td> 
<td width= "75% " align = "left">< input type = "text" name = "weekhour" size= "20" 
value = "<?php echo $ weekhour;?>" /> 
<font color = "##FF0000">* </font ><?php echo "<font size= '2'color = 'FF0000'>". 
@ $ weekhourl. "</font >";?> </td> 
</tr> 
<tr> 
<tdwidth="25%" align= "center"> 周 数 </td> 
<tdwidth="75%" align = "left"> < input name = "weeknum" type = "text" id = 
"weeknum" value = "<?php echo $ weeknum;?>" size ="20" /> 
<font color = " 井 FE0000"> * </font ><?php echo "<font size= '2'color= 'FF0000'>". 
@ $ weeknuml. "</font >";?></td> 
</tr> 
<tr> 








<td align = "center" > 开课 学 期 </td> 
<td align = "left">< select name = "offerterm" id = "offerterm"> 
< option value = ""> 请 选择 学 期 </option> 
<?php 
$ array = getdate( ); 
$ year = $ array["year"]; 
$month= $array["mon"]; 
if ($month<=7) for( $i=0;$i<3;$i+t+) 
{ if (S$offerterm==( $year— $i-1)."—".($year- $i)."(2)") 
echo "<option selected>".( $year— $i—-1)."-".($year— $i)."(2) 
</option>"; 
else echo "<option>".( $year— Si-1)."-".(S$year- $i)."(2)</option>"; 
if ($ offerterm==( $year— $i-1)."-".($year— $i)."(1)") 
echo "<option selected>".( $year— $i-1)."-".(S$year—- $i)."(1) 
</option>"; 
else echo "<option>".($year— $i-1)."—".($year— $i)."(1)</option>"; 
} 
else for($i=0;$i<3;$i++) 
{ 
证 ($ offerterm==( $year— $i)."—".($year- $i+1)."(1)") 
echo "<option selected>". ($year— $i)."—".($year— $i+1)."(1) 
</option>"; 
else echo "<option>".($ year— $i)."—".($year—- $i+1)."(1)</option>"; 
if ( $ offerterm==( $year— $i-1)."—-".($year- $i)."(2)") 


echo "<option selected>". ($year— $i-1)."-".($year—- $i)."(2) 
</option>"; 
else echo "<option>".( $year— Si-1)."-".($year- $i)."(2)</option>"; 
} 
> 
</select> 
< font color ="##FF0000">* </font ><?php echo "< font size = '2' color = 'FF0000 7 
>".@ $ offerterm1. "</font >";?></td> 
</tr> 
<tr> 


<tdwidth="25%" align= "center"> 任 课 教师 </td> 
<tdwidth="75%" align= "left">< select name = "teacherid" id= "teacherid"> 
<option value = ""> 请 选择 教师 </option > 
<?php 
5$ sql = "select * from teacher order by teacherid,teachername"; 
$ rsl=mysql_query( $ sql); 
$ rowl = mysql_fetch_assoc( $ rs1); 
while( $ rowl) 
{ if (strcmp( $ teacherid, $ rowl["teacherid"])==0) 
echo "< option value= '". $ rowl["teacherid"]."' selected>". $ rowl 
["teacherid"]." ". $ rowl["teachername"]."</option>"; 
else echo "< option value= '". $ rowl["teacherid"]."’>". $rowl 
["teacherid"]." ". $ rowl["teachername"]."</option >"; 
$ rowl = mysql_fetch assoc( $ rs1); 


?> 
</select ></td> 
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</tr> <tr> 
<td colspan = "2" align = "center" bgcolor = "#328EBE"> 
<input type= "submit" name= "update" value = "修改 " id= "update" /> 
<input type = "reset" name = "back2"” value = "返回 "onclick = " location. href = 
"Offercourse. php'"/> 
</td> 


</tr> 


</table ></form></td> 


</tr> 


</table > 


</body > 


10.4.6 


学 生成 绩 统计 


Countscore. php 学 生成 绩 统计 页 面 。 系 统 起 始 仅 显 示 查 询 顶 部 , 当 系统 管理 员 选 择 一 
个 专业 后 ,才能 级 联 出 该 专业 的 所 有 班级 。 当 系统 管理 员 选 择 一 个 班级 和 一 个 学 期 ,并 单 击 
“查询 ”按钮 后 ,页 面 才 会 显示 每 位 学 生 的 单 科 成 绩 , 总 分 .平均 分 和 名 次 。 运 行 界面 如 
图 10-15 所 示 。 


学 号 

















国 | 志 Ss 到 国 | 讲 5S 划 国人 者] 
0 2016- 2017(2 期 学 生成 绩 统 计 表 











1530505101 





100 
1530505102 431 
1530505103 505 





1530505104 | 庄 梓 敏 | 81 67 
1530505105 | 陈 月 得 | 67 78 





1530505106 | 谢 佛 强 
1530505107 | 邓 钧 元 80 


图 10-15 学 生成 绩 统 计 页 面 

















相关 代码 如 下 : 


<head> 


<meta http— equiv = "Content - Type" content = "text/html; charset =utf— 8" /> 
< script src="../scripts/Com. js"></script > 


<title> 学 


生成 绩 统计 </title> 


< style type = "text/css"> 


table { 


width: 90%; 


margin: 0 auto; 


' 
</style> 


<div style = "Display:none"> 


<?php 


include "../Fun. php"; 





include "../IsLogin. php"; 


?> 
</div> 
</head > 
<body> 
< script type = "text/javascript"> 
// 选 择 专业 改变 班级 
function change( ) 
{ 
Var bms = document. forml .major. value; 
//bms 的 值 为 :班级 序号 | 入 学 年 份 - 班 名 | 班级 序号 | 人 学 年 份 - 班 名 | 
if (bms =="") {window.alert(" 专 业 名 不 能 为 空 ") ;document. forml. major. focus();} 
Var bm = bms. split("|"); 
// 按 "| "将 bms 分 成 若干 子 串 , 并 依次 存 人 数组 中 , bm 的 长 度 为 "| "的 个 数 + 1 
for(i=0;i<(bm. length—1)/2;i++) 
//classl 的 value 值 为 班级 序号 , text 值 为 "入学 年 份 - 班 名 " 
{ with(document. forml. classl) 
{ length = (bm.length—1)/2+1; 
options[i+1].value = bm[2*x 1i]; 
‘options[i+1].text =bm[2*i+1]; 
} 


} 
function check( ) 
{ 
if (document. forml.classl. value == "") 
{ 
alert(" 请 选择 专业 班 !"); 
document. forml. classl.focus(); 
return false; 
} 
if (document. forml. term. value == "") 
{ 
alert(" 请 选择 学 期 !"); 
document. forml. term. focus( ); 
return false; 


} 
</script > 
< form method= "post" name= "forml"> 
<divalign = "center"> 
< font style = "font - family: ' 华 文 新 魏 '; font - size:20px"> 学 生成 绩 统 计 </font > 
<br> 
< select name = "major" id="major" onChange = "change()" > 

< option value = "" > 请 选择 专业 </option> 

<?php 
$ sqlx= "select distinct majorname from class"; 


$ rsl=mysql_query( $ sqlx); 
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$ rowl = mysql_fetch assoc( $ rs1); 
// 每 取出 一 个 专业 ,就 输出 其 全 部 班级 
while( $ rowl) 


{ $zy= $rowl["majorname"]; 


$ sqlx= "select distinct classid, enrollyear, classname from class where majorname = 

zy， 

$ rs2 = mysql_query( $ sqlx); 

$ row2 = mysql_fetch_assoc( $ rs2); 

$class=""; 

while( $ row2) 

{ $class. = $row2["classid"]."|". $row2["enrollyear"]."—". $ row2["classname"]."|"; 
$ row2 = mysql_fetch_assoc( $ rs2); 


} 
Ec 
< option value = "<?php echo $ class;?>"><?php echo $ rowl["majorname"];?></option> 
<?php 
$ rowl = mysql_fetch_assoc( $ rs1); 
| 
?> 
</select > 
<select name= "classl" id= "classl" > 
< option value = "" selected> 请 选择 班级 </option > 
</select> 
< Select name = "term"> 
< option value = ""> 请 选择 学 期 </option > 
<?php 
$ array = getdate( ); 
$ year = $ array[ "year" ]; 
$ month= $ array[ "mon"]; 
if ($month<=7) for($i=0;$i<3;$i++) 
{ echo "<optionvalue= '".($year- $i-1)."-".($year- $1i)."(2)>" 
.($year—- $i-1)."—".($year— $i)."(2)</option>"; 
echo "<optionvalue= '".(S$year- $i-1)."-—".($year—- $i)."(1)'>" 
($year— $1i-1)."—".($year- $i)."(1)</option>"; 
} 
else for($i=0;$i<3;$it+) 
{ 
echo "<option value= '".($ year— $i)."—".(S$year— $i+1)."(1)>" 
($year— $i)."—".($year— $i+1)."(1)</option>"; 
echo "<option value= '".($year— $i-1)."-—".($year- $i)."(2)'>" 
($year— $i-1)."—".($year— $1i)."(2)</option>"; 
} 
> 
</select> 
< input name = "search" type = "submit"” value = "查询 ”onclick = "return check()"/> 
<br /> 
<?php 


if(isset( $ _POST[ "search" ])) 





$ classid= $ _POST["class1"]; // 获 取 班 级 序号 
$ term= $ _POST["term"]; // 获 取 开 课 学 期 


$ rs0=mysql_query("select * from class where classid= '$ classid'"); 


$ row0 = mysql_fetch_array( $ rs0); 

echo 5$ row0["enrollyear"]. $ row0["majorname"]. $ row0 [" classname"]."&nbsp; &nbsp;". 
$ term. "学 期 学 生成 绩 统计 表 "; 

// 取 出 指定 班级 的 学 生 的 学 号 、 姓 名 

$ sql = "select * from student where classid= '$ classid'"; 


$ rsl=mysql_query( $ sql); 


$ xss = mysql_num_rows( $ rsl1); // 算 出 班级 学 生 数 $ xss 

$ rowl = mysql_fetch_array( $ rs1); // 数 组 的 键 名 可 以 是 整数 和 字段 名 
$i=1; 

while( $ rowl) 

// 自 动 建立 数组 $ no、$ name 


S$Sno[ $i]= $rowl["studentid"]; 
$ name[ $ i] = $ rowl["studentname"]; 
$ rowl = mysql_fetch_array( $ rs1); 
$itts 
} 
// 取 出 指定 学 期 .指定 班级 所 开设 的 课程 号 ,课程 名 
$ sql = "select distinct course. courseid, coursename from course, offercourse where course. 
courseid = offercourse. courseid and classid= '$ classid'and offerterm= '$ term’'"; 
$ rs2=mysql_query( $ sql); 


$kcs= mysql_num_rows( $ rs2); // 算 出 课程 门 数 $ kcs 
if ($kcs== 0) echo "<br><center > 暂 无 记录 </center >"; 
else 


{ 
$ row2 = mysql_fetch_array( $ rs2); 
// 每 选择 一 门 课程 ,就 取出 指定 学 期 .指定 班级 的 学 生 该 门 课程 的 成 绩 
$1=1; //$ i 表示 课程 序号 
while( $ row2) 
{ // 自 动 建立 数组 $ kem 
$ kcm[ $ i] = $ row2[ "coursename" ]; //$ kcn 存放 课程 名 
$ courseid= $ row2["courseid"]; 
$ sql = "select * from score, student where score. studentid = student. studentid and 
classid= '$ classid' and offerterm= '$ term' and courseid= '$ courseid'"; 
$ rs3=mysql_query( $ sql); 
$ row3 = mysql]_fetch_array( $ rs3); 
$j=1; //$j 表 示 学 生 序号 
while( $ row3) 
{ 
// 自 动 建立 数组 $ course 
$course[ $j][$i]= $row3["score"]; // 第 $j 位 学 生 第 $i 号 课 的 成 绩 
$ row3 = mysql_fetch_array( $ rs3); 
$ j++; 
} 
$ row2 = mysql_fetch array( $ rs2); 
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$i++; 

} 
// 算 出 每 位 学 生 的 总 分 ,平均 分 
for($i=1;$i<= $xss; $i++) 
. // 自 动 建立 数组 

$ sum[ $i]=0; 

$ sum_sort[ $i] =0; 

for ($j=1;$j<= $kcs; $j++) 

{ $sum[ $i]+=@$course[ $i][$j]; // 第 $i 位 学 生 第 $j 号 课 的 成 绩 

$ sum_sort[ $ i] += @ $ course[ $ i][ $j]; 

} 

$ avg[ $i] = round( $ sum[ $i]/$ kcs,1); // 四 舍 五 人 到 1 位 小 数 . 
} 


rsort( $ sum_sort); 
// 对 数组 $ sum_sort 的 值 降 序 排序 ,数组 的 键 名 修改 为 从 0 开始 的 整数 
echo "<table width = '100 % ' border = '1' cellspacing = '0 '>"; 
echo "<tr>"; 
echo "< td align = 'center ?学 号 </td>"; 
echo "< td align = 'center > 姓 名 </td>"; 
for ($j=1;$j<= $kcs;$ j++) 
echo "<tdalign= 'center'width= '7% '>". $kcm[ $j]."</td>"; 
echo "< td align = 'center > 总 分 </td>"; 
echo "<td align= 'center 人 > 平均 分 </td>"; 
echo "< td align = 'center > 名 次 </td>"; 
echo "</tr >"; 
for($i=1;$i<= $xss;$ i++) 
{ 
echo "<tr>"; 
echo "<tdalign= 'center'>". $ no[ $i]."</td>"; 
echo "<tdalign= 'center '>". $ name[ $ i]."</td>"; 
for ($j=1;$j<= $kcs;$ j++) 
echo "<tdalign= 'center'width= 7% '>". @ $ course[l $i][ $j]."</td>"; 
echo "< td align = 'center >". $ sum[ $i]."</td>"; 
echo "<tdalign= 'center'>". $avg[ $i]."</td>"; 
for ($j=0;$j<$xss; $j++) 
if ($ sum[ $i] == $ sum_sort[ $j]) { 
echo "<tdalign= 'center >". ($j+1)."</td>"; 
break; 
} 
echo "</tr >"; 
} 
echo "</table >"; 


} 

?> 
</div> 
</form> 
</body > 
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10.5 任课 教师 子 系统 的 实现 


当 任 课 教师 登录 后 ,用 户 权 限 主页 Index. php 的 运行 界面 如 图 10-16 所 示 , 单 击 左边 的 
功能 菜单 ,就 会 在 右边 显示 执行 结果 。 


学 生 学 籍 成 绩 管 理 系统 


当前 用 户 类 别 : 教师 , 用 户 名 : 2010000744 








工 号 : 2010000744 
姓名 : | 陈 汉 忠 
职称 : 副教授 
手机 : 





图 10-16 个 人 信息 页 面 


10.5.1 学 生 学 籍 查询 
Student. php 学 生 学 籍 查 询 页 面 。 系 统 起 始 仅 显示 查询 顶部 , 当 任 课 教师 选择 一 个 学 


期 后 ,才能 级 联 出 该 学 期 任教 的 班级 , 当 任课 教师 选择 一 个 班级 ,并 单 击 "查询 "按钮 后 ,页 面 
才 会 分 页 显示 查询 结果 。 运 行 界面 如 图 10-17 所 示 。 





[请 由 笃 学 期 “ 辆 | 请 洁 择 孝王 级 贺 | 查询 
L ”2015 计算 机 网 络 技术 1 班 学 生 和 名单 


1 出 生日 期 










































1530505101 李 遍 陀 男 1992-01-01 0 
1530505102 | 际 忠 | 男 | 1992.0101 | 0 
1530505103 | 印 伟 发 男 “| 1992-01-01 0 
1530505104 | ”请 # 数 “| 女 | 1992-01-01 0 
1530505105 |。 陈 月 得 女 “| 1992-01-01 0 
1530505106 |。 谢 佛 强 男 1992-01-01 0 
1530505107 2 元 男 1992-01-01 0 
1530505108 贡 电 入 男 1992-01-01 0 
1530505109 i 男 1992-01-01 0 
1530505110 | 陈 仁 杰 男 1992-01-01 0 
1 2 3 4 下 -页 共 | 页 











10-17 学 生 学 籍 查询 页 面 
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相关 代码 如 下 : 


<head> 
<meta http— equiv = "Content - Type" content = "text/html; charset =utf -8" /> 
< link href ="../styles/com. css" rel = "stylesheet" /> 
< script src ./scripts/Com. js"></script > 
<style type = "text/css"> 
table { 
width: 70%; 
margin: 0 auto; 





} 
</style> 
<title> 学 生 学 籍 查询 </title> 
</head> 
<body> 
<div style = 'Display:none '> 
<?php 
include "../Fun. php"; 
include "../IsLogin. php"; 
$userid = $ _SESSION[ "userid" ]; 
?> 
</div> 
< script type = "text/javascript"> 
function change( ) 
人 
// 选 择 任教 学 期 改变 任教 班级 
Var bms = document. form1l. term. value; 
if (bms == "") {window.alert(" 任 教学 期 不 能 为 空 ");document. form1l. term. focus();} 
bms. split ("|"); 
将 bms 分 成 若干 子 串 ,并 依次 存 人 数组 中 ,bm 的 长 度 为 "1" 的 个 数 +1 
for(i=0;i<(bm. length— 1)/2;i++) 
//classl 的 value 值 为 班级 序号 ,text 值 为 "入 学 年 份 + 专业 名 + 班 名 " 
{ with(document. forml.classl) 
{ length = (bm.length— 1)/2+1; 
options[i+1].value = bm[2*xi]; 
options[i+1].text =bm[2*i+1]; 








} 
function check( ) 
{ 
if(document. forml. term. value == "") 
{ ”alert(" 请 选择 任教 学 期 !"); 
document. forml. term. focus( ); 
return false; 
} 
if(document. forml.classl.value == "") 
{ ”alert(" 请 选择 任教 班级 !"); 
document. forml. classl. focus(); 
return false; 





</script> 
< form method = "post" name = "form1"> 


< div align ="center"> 
< font style = "font - family: ' 华 文 新 魏 '; font - size:20px" > 学 生 学 籍 查询 </font ><br> 
< Select name = "term" id = "term" onChange = "change( ) "> 
<option value = ""> 请 选择 学 期 </option > 
<?php 
$ sql = "select distinct offerterm from offercourse where teacherid= ' $userid 
Order by offerterm desc"; 
$ rsl= mysql_query( $ sql); 
$ rowl = mysql_fetch_assoc( $ rs1); 
// 每 读 取 一 个 学 期 ,就 能 检索 出 自己 在 本 学 期 任教 的 班级 
while( $ rowl) 
{ $xq= $rowl["offerterm"]; // 开 课 学 期 
$ sql = " select distinct class. classid, enrollyear, majorname, classname from 
class, offercourse where class. classid = offercourse. classid and teacherid= 
'$ userid'and offerterm= '$ xq’'"; 
$ rs2=mysql_query( $ sql); 
$ row2 = mysql_fetch_assoc( $ rs2); 
$bxs=""; ”// 班 级 序号 
while( $ row2) 
{ $bxs. = $row2["classid"]."|". $ row2["enrollyear"]. $ row2["majorname" ]. 
$ row2["classname"]."|"; 
$ row2 = mysql_fetch_assoc( $ rs2); 


} 


Ve 
< option value = "<?php echo $ bxs;?>"><?php echo $ xq;?></option> 
<?php 
$ rowl = mysql_fetch assoc( $ rs1); 
} 
?> 
</select > gnbsp; 


< select name= "classl" jd = "classl"> 
<option value = ""> 请 选择 任教 班级 </option> 

</select > 

< input name = "search" type = "submit” value = "查询 ” onclick = "return check( )"/> 
<br /> 

<?php // 只 有 单 击 “ 查 询 " 按 钮 或 地 址 栏 page 有 值 , 才 能 显示 记录 

if(isset( $ _REQUEST[ "search"]) || isset( $ _REQUEST["page"])) 

{ if(isset( $_REQUEST["search"])) $_SESSION["classid"] = $ _REQUEST[ "class1"]; 
$ sqlx= "Select * from class where classid= '". $ _SESSION["classid"]."'"; 
$ rs3=mysql_query( $ sqlx); 
$ row3 = mysql_fetch assoc( $ rs3); 
echo $ row3["enrollyear"]. $ row3["majorname"]. $ row3["classname"]." 学 生 名 单 "; 


?> 
<table> 
<thead> 
<tr> 
<thwidth="20% "> 学 号 </th> 
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<th width= "20s "> 姓名 </th> 

<th width= "20g% "> 性 别 </th> 

<thwidth="20% "> 出 生日 期 </th> 

<th width = "20$ "> 总 学 分 </th> 
</tr> 


</thead> 

<?php 

if(isset( $ _REQUEST[ "search"]) || isset( $ _REQUEST[ "page"])) 
// 只 有 单 击 “查询 "按钮 或 地 址 栏 page 有 值 ,才能 显示 记录 


{ 


$sql="select * from student where classid= '". $ _SESSION["classid"].""™"; 
loadinfo( $ sql); 


function loadinfo( $ sqlstr) 


. 


$ result = mysql_query( $ sqlstr); 

$ total = mysql_num_rows( $ result); 

if (isset( $ _REQUEST[ "search"])) $ page =1; // 每 次 单 击 “ 查 询 ” 按 钮 , 从 第 1 页 开始 显示 
$ page = isset( $ _REQUEST[ 'page '])?intval( $ _REQUEST[ ‘page ’]):1; 

// 获 取 地 址 栏 中 page 的 值 ,不 存在 则 设 为 1 


$ num= 15; // 每 页 显示 15 条 记录 

$ url = ‘Student. php'; // 本 页 URL 

$ pagenum = ceil( $ total/ $ num); // 获 得 总 页 数 ,ceil( ) 返 回 不 小 于 x 的 最 小 整数 
$ prepg= $ page— 1; // 上 一 页 


$ nextpg= ( $ page == $ pagenum? 0: $page +1); // 下 一 页 
//limit m,n: 从 m+1 号 记录 开始 , 共 检 索 n 条 
$ new_sql = $ sqlstr." limit ". ($ page—1) * $ num.",". $ num; // 按 每 页 记录 数 生 成 查询 语句 
$ new_result = mysql_query( $ new_sql); 
if( $ new_row = @mysql_fetch_array( $ new_result)) 
{ // 若 有 查询 结果 , 以 表格 形式 输出 
do 
{ 
list( $ id, $ name, $ pwd, $ sex, $ birthday, $ classid, $ credit) = $ new_row; 
// 数 组 的 键 名 为 从 0 开始 的 连续 整数 
echo "<tr>"; 
echo "<td width= '20% '>$ id</td>"; 
echo "<td width= '20% '>$ name </a></td>"; 
echo "<td width= '20% '>$ sex </td>"; 
echo "<td width= '20% '>$ birthday </td >"; 
echo "<td width= '20% '>$ credit </td>"; 


echo "</tr >"; 
}while( $ new_row = mysql_fetch_array( $ new_result)); 
// 开 始 分 页 导航 条 代码 
$ pagenav = ""; 
if( $ prepg) // 如 果 当 前 显示 第 一 页 , 则 不 会 出 现 " 上 一 页 " 


$ pagenav. = "<a href = '$ url?page= $ prepg'> 上 一 页 </a> "; 
for( $i=1;$i<= $pagenum; $i++)  //$ pagenun 为 总 页 数 
if( $ page == $i) $pagenav. ="<b><font color = '# FF0000 '> $i</font > 
</b> gnbsp;"; 
else $ pagenav. =" <a href = '$ url?page= $ i'>$ i"."gnbsp;</a>"; 





if( $ nextpg) // 如 果 当 前 显示 最 后 一 页 , 则 不 会 出 现 " 下 一 页 " 
$ pagenav. =" <a href = ' $ url?page = $ nextpg '> 下 一 页 </a>"; 
$ pagenav. = "gnbsp;&nbsp; 共 ". $ pagenum. "页 "; 
// 输 出 分 页 导航 
echo "<tr><tdcolspan= '5'>". $ pagenav. "</td></tr >"; 
} 
else 
echo "<tr><td colspan = '5 > 暂 无 记录 </td></tr>"; 
} 
?> 
</table> 
</div> 
</form> 
</body > 


10. 5.2 ”学生 成绩 管理 


Score. php 学 生成 绩 管理 页 面 。 系 统 起 始 仅 显 示 查 询 项 部 , 当 任课 教师 选择 一 个 学 期 
后 ,才能 级 联 出 该 学 期 任教 的 班级 , 当 任课 教师 再 选择 一 个 班级 ,并 单 击 “ 查 询 ” 按 钮 后 ,系统 
会 检查 任教 班级 中 的 学 号 、 任 教 课程 号 在 成 绩 表 中 是 否 有 相应 记录 ,车 有 则 跳 过 ,无 则 自动 
插入 (包括 学 号 ,课程 号 .开设 学 期 ) ,然后 在 页 面 的 中 下 部 分 页 显示 查询 结果 。 运 行 界面 如 
图 10-18 所 示 。 

















细 | 请 选 生字 期 “ 国 。| 选 怪 任 才 珀 级 国 | 二 启 


汕头 职业 技术 学 院 学 生成 绩 登记 表 


班级 : 2015 计 算 机 网 络 技术 1 班 科目 : | 计算 W 滞 图 学 期 : 2016-2017(2) 
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图 10-18 学 生成 绩 管理 页 面 
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学 号 列 为 只 读 ,但 成 绩 列 可 增删 、 改 。 任 课 教师 对 学 生 的 课程 成 绩 增 删改 后 , 单 击 
“保存 ”按钮 即 可 。 如 果 一 位 教师 在 同一 个 班级 同时 任教 多 门 课程 , 则 选择 科目 下 拉 框 中 的 
另 一 门 课程 ,页 面 立即 显示 另 一 门 课程 的 学 生成 绩 单 。 

相关 代码 如 下 : 


<head> 

<meta http 一 equiv = "Content - Type" content = "text/html; charset = utf - 8" /> 
<title> 学 生成 绩 管理 </title> 

< style type = "text/css"> 


< 一 二 
af 
text — decoration: none; 
} 
.tablel { 
background — color: #9CC; 
} 
= 一 > 
</style> 


< script language = "javascript"> 
function check( ) 
{ 
if(document. forml. term. value == "") 
{ ”alert(" 请 选择 任教 学 期 !"); 
document. forml. term. focus( ); 
return false; 
} 
if(document. forml.classl. value == "") 
{ alert(" 请 选择 任教 班级 !"); 
document. forml. classl. focus( ); 
return false; 


' 


function changel() 
{ // 选 择 任教 学 期 改变 任教 班级 
Var bms = document. form1. term. value; 
//bms 的 值 为 : 班级 序号 | 入 学 年 份 + 专业 名 + 班 名 号 |…| 开 课 学 期 
if (bms == "") {window.alert(" 任 教学 期 不 能 为 空 ");document. forml. term. focus();} 
Var bm = bms. split("|"); 
// 按 "| "将 bms 分 成 若干 子 串 ,并 依次 存 人 数组 中 ,bm 的 长 度 为 "| "的 个 数 +1 
for(i=0;i<(bm. length— 1)/2;i++) 
{ with(document.forml.classl) 
{ length = (bm.length- 1)/2+1; 
options[i+1].value = bm[2*i]; // 下 拉 框 classl 的 value 值 为 班级 序号 
options[i+1].text =bm[2*i+1]; // classl 的 text 值 为 "入 学 年 份 + 专业 名 + 班 名 " 


} 
} 
</script > 
<div style = 'Display:none> 
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<?php 


include "../Fun. php"; 
include "../IsLogin. php"; 
$userid= $ _SESSION["userid" ]; 


Pe 
</div> 
</head > 
<body> 
<?php 
if (isset( $ _REQUEST[ "save"])) 
{ 
$ kch= $ _REQUEST[ "kch" ]; //$ kch 为 变量 名 
$ xh= $_REQUEST["xh" ]; //$ xh 为 数组 名 
$ score = $ _REQUEST[ "score" ]; //$ score 为 数组 名 
for( $i=0;$i<count( $ xh); $ i++) 
{ $ sql = "update score set score=". $ score[ $i]." where studentid = '". $ xh[ $i]."'and 


} 


courseid= '$ kch'"; 
mysql_query( $ sql); 
} 
echo "< script >alert( ' 保 存 成 功 ! ');</script >"; 


$xq= @$ _REQUEST[ "term"]; //$ xq 为 : 班级 序号 | 入 学 年 份 + 专业 名 + 班 名 号 |.…| 开 课 学 期 
$ bx = @ $ _REQUEST[ "class1" ]; //$ bx 为 班级 序号 
if ($xq!="" && $bx!="" ) 


{ 


// 取 出 选中 学 期 ,并 存 人 $ xql 中 

$ xqs = explode("|", $ xq); 

// 使 用 "1", 将 字符 串 分 为 若干 个 子 串 ,并 存 入 数组 中 . 数组 的 长 度 = "|" 的 个 数 +1 

$ xql = $ xqs[count( $ xqs) -1]; //$ xql 为 选中 的 学 期 ,数组 元 素 的 最 大 下 标 为 数组 长 度 -1 

// 取 出 班级 序号 对 应 的 班级 名 称 

$ sql =" select * from class where classid= '$ bx"; 

$ rsl = mysql_query( $ sql); 

$ rowl = mysql_fetch_assoc( $ rs1); 

$bm= $ rowl["enrollyear"]. $ rowl["majorname"]. $ rowl["classname"]; 

// 取 出 任课 教师 在 指定 学 期 .指定 班级 任教 的 课程 号 、 课 程 名 

$sql = " select course. courseid, coursename from course, offercourse where course. courseid = 

offercourse. courseid and offerterm= '$ xql 'and classid= '$ bx' and teacherid= ' $ userid’'"; 

$ rs2= mysql_query( $ sql); 

$ row2 = mysql_fetch_assoc( $ rs2); // 有 些 教师 在 一 个 班级 可 能 同时 任教 两 门 课程 

// 检 查 任教 班级 中 的 学 号 .课程 号 在 score 表 是 否 有 相应 记录 ,无 则 插入 (包括 学 号 .课程 号 .开设 
学 期 ) 

// 为 下 拉 框 kch 填充 选项 





while( $ row2) 
{ 
$kch= $ row2["courseid"]; 
$ kcm= $ row2["coursename" ]; 
$kchs= $ kchs. $ kch."|"; 
$kcms= $ kcms. $ kcm."|"; 
$sql="select * from student where classid= '$ bx'"; 
$ rs5=mysql_query( $ sql); 
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$ row5 = mysql_fetch_assoc( $ rs5); 
while( $ row5) 
{ $ xh= $ row5["studentid"]; 
$ sql= "select * from score where studentid= '$ xh'and courseid= '$ kch'"; 
$ rs6= mysql_query( $ sql); 
if (mysql_num_rows( $ rs6) == 0) // 车 不 存在 指定 学 号 .课程 号 的 记录 , 则 插入 
| 


$ sql = "insert into score( studentid, courseid, offerterm) 
values('$ xh’','$ kch’,'S$ xql')"; 
mysql_query( $ sql); 
} 
$ row5 = mysql_fetch assoc( $ rs5); 
} 
$ row2 = mysql_fetch_assoc( $ rs2); // 取 出 教师 任教 的 下 一 门 课 
} 
// 显 示 指 定 班级 、 指 定 课程 号 的 学 生成 绩 
$a= explode( '| ', $ kchs); // 使 用 '| ', 将 字符 串 分 为 若干 个 子 串 ,并 存 人 数组 $a 中 
$kch= @$ _REQUEST["kch"]; // 其 中 kch 为 下 拉 框 的 名 称 
if ($kch=="") $kch= $a[0]; 
$sql="select * from student, score, course where student. studentid = score. studentid and 
score. courseid = course. courseid and classid= '$ bx' and course. courseid= '$ kch'"; 
$ rs7 = mysql_query( $ sql); 
$ count = mysql_num_rows( $ rs7); //$ count 为 结果 集 $ rs7 的 总 人 数 
if ($count $2==0) 
{ $part= $count/2; 
//limit m,n: 从 m+ 1 号 记录 开始 , 共 检 索 n 条 记录 
$ rs7a=mysql_query( $ sql." limit 0, $ part"); 
$ rs7b = mysql_query( $ sql." limit $ part, $ part"); 








} 
else 
{ S$part=(int)($ count/2+1); 
$ rs7a= mysql_query( $ sql." limit 0, $ part"); 
$ rs7b = mysql_query( $ sql." limit $ part,".( $ part—1)); 
} 
$ row7a= mysql_fetch_assoc( $ rs7a); 
$ row7b= mysql_fetch_assoc( $ rs7b); 
} 
?> 
<form id="forml" name = "form1" method = "post" action = "score. php"> 
< center>< font style = "font - family: ' 华 文 新 魏 '; font - size:20px"> 学 生成 绩 管理 </font > 
</center > 
<table width = "80g% " border = "0" align = "center" cellpadding = "0" cellspacing = "0" > 
区 
< td height = "30"> 
<table width= "70%" border = "1" align = "center" cellpadding = "0" cellspacing = 
"0"> 
<tr> 
< td height = "25" align = "center">< img src = "../images/checkarticle. gif" 
width= "15" height = "15" /> gnbsp; 
< select name= "term" onChange = "changel()"> 
<option value =""> 请 选择 学 期 </option> 





$ sql = "select distinct offerterm from offercourse where teacherid = ' $userid 
order by offerterm desc"; 
$ rsl = mysql_query( $ sql); 
$ rowl = mysql_fetch_assoc( $ rs1); 
// 每 读 取 一 个 学 期 ,就 能 检索 出 自己 在 本 学 期 任教 的 班级 
while( $ rowl) 
{ $xq2= $rowl["offerterm"]; //$ xq2 为 下 拉 框 term 的 选项 
$ sql = "select distinct class. classid, enrollyear, majorname, classname from 
class, offercourse where class. classid = offercourse. classid and teacherid = 
'$ userid' and offerterm= '$ xq2'"; 
$ rs2=mysql_query( $ sql); 
$ row2 = mysql_fetch assoc( $ rs2); 
$ bxs =""; // 班 级 序号 
while( $ row2) 
{ $bxs. = $row2["classid"]."|". $ row2["enrollyear"]. $ row2["majorname" ]. 
$ row2["classname"]."|"; 
$ row2 = mysql_fetch_assoc( $ rs2); 


?> 
< option value = "<?php echo $ bxs. $ xq2;?>"><?php echo $ xq2;?></option> 
php 
$ rowl = mysql_fetch_assoc( $ rs1); 
} 
kg 


</select > &nbsp;&nbsp; 
< select name = "classl" id= "classl"> 
< option value= ""> 选 择 任 教 班级 </option> 
</select > gnbsp; 
< input type = "submit" name = "search" jd = "search" value = "查询 " onclick= "return check()"/> 
</td> 
</tr> 
</table> 
</td> 
</tr> 
<?php 
if ( $xq!="" && $ bx!= 
{ 





?> 
过 人 
<td height = "35" align = "center">< font size= "+2"> 汕 头 职业 技术 学 院 学 生成 绩 登 记 
表 </font ></td> 
</tr> 
<te 


< td height = "255" valign = "top"> 
<table width= "95% " border = "0" align= "center" cellpadding = "2" cellspacing = 
> 
tr 
<td width = "38 名 "> 班级 : <?php echo $ bm;?></td> 
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<td width= "38 当 "> 科 目 : 
< select name = "kch" id = "kch" onchange = "change2()"> 
<?php 
$a=explode( '|', $ kchs); //S$ a: 存放 课程 号 
$b=explode('|', $ kcms); //$ b: 存放 课程 名 
for($i=0;$i<count( $a)—1;$ i+t+) 
{?> 
< option value= "<?php echo $ a[ $ i];?>" <?php if (strcmp( $ a[ $i], $ kch) == 0) 
echo "selected" ;?> ><?php echo $ b[ $ i];?></option> 
<?php } ?> 
</select ></td> 

<td width= "24$% "> 学 期 : <?php echo $ xql;?></td> 

</tr> 


</table> 
<table width= "95% ”border = "1" align= "center" cellpadding = "0" cellspacing = 





class= "tablel"> 


<tr> 


<td width= "12%" align = "center"> 序 号 </td> 
<td width="12%" height = "20" align = "center"> 学 号 </td> 
<td width= "12% ”height = "20" align = "center"> 姓 名 </td> 
<td width= "14% ”height ="20" align = "center"> 成 绩 </td> 
<td width= "12%"” align = "center"> 序 号 </td> 
<td width= "12% ”height = "20"”align = "center"> 学 号 </td> 
<td width= "12%" height = "20" align = "center"> 姓 名 </td> 
<td width= "14 多 "height = "20" align = "center"> 成 绩 </td> 
</tr> 
<?php 
$1i=1; 














while( $ i<= $ part) 


?> 
<tr> 


<tdwidth="12%" align= "center"><?php echo $ i;?></td> 

<td width = "12%" height = "20" align= "center">< input name = "xh[ ]" type = 
"text" id = "xh[ ]" value = "<?php echo $ row7a[ "studentid"];?>" size = "10" 
readonly= "true" onKeyDown = "return false;"/></td> 

<tdwidth="12%" height ="20" align= "center"><?php echo $ row7a 
["studentname" ];?></td> 

<td width = "14%" height = "20" align = "center">< input name = "score[ ]" type = 
"text" id= "score[ ]" size = "10" onKeyDown = " if (event. keyCode == 13) return 
false;" value = "<?php echo $ row7a["score"]; ?>"/></td> 

<tdwidth="12%" align= "center"><?php echo $ i+ $ part;?></td> 

<td width = "12%" height = "20" align = "center">< input name = "xh[ ]" type = 
"text" id="xh[]" value = "<?php echo @ $ row7b[ "studentid"];?>" size= "10" 
readonly = "true" onKeyDown = "return false;"/></td> 

<td width = "12%" height = "20" align =" center" > <? php echo @ $ row7b 
["studentname" ];?></td> 

<td width= "14%" height = "20" align = "center">< input name = "score[ ]" type = 
"text" id= "score[ ]" size = "10" onKeyDown = "if(event. keyCode == 13) return 
false;" value = "<?php echo @ $ row7b[" score"]; ?>" <?php if ($1>$count) 
echo "readonly"; ?>/></td> 





</tr> 
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<?php 

$ row7a = mysql_fetch assoc( $ rs7a); 
$ row7b = mysql_fetch_assoc( $ rs7b); 
S i++ 

} 

?> 

<tr> 


<td height = "20" colspan = "8" align= "center">< input type = "submit" name = 
"save" id = "save" value= "保存" /></td> 
</tr> 
</table> 
</td> 
</tr> 
<?php }?> 
</table> 
</form> 
< script language = " javascript"> 
function change2() 
{ var x= document.forml.kch. value; 
window. location. replace( "score. php?term = <?php echo $ xq;?> &classl = <?php echo $ bx;?> 
Skch= "+x); 
} 
</script > 
</body > 


10.6 学 生子 系统 的 实现 


当 学 生 登 录 后 ,用 户 权限 主页 Index. php 的 运行 界面 如 图 10-19 所 示 , 单 击 左边 的 功能 
菜单 ,就 会 在 右边 显示 执行 结果 。 


学 生 学 籍 成 绩 管理 系统 


当前 用 户 类 别 : 学 生 , 用 户 各 : 1530505101 








”> 管理 菜单 
专业 计算 机 网 络 技术 
上 @ 个 人 信息 查 词 班级 名 称 | 2015 计 算 机 网 络 技术 ] 班 
最 成绩 可 询 学 号 | 1530505101 
日 杰 码 修改 Sn | 
@ 退出 | 性 别 | 男 
出 生日 期 1992-01-01 
总 学 分 0 


图 10-19 个 人 信息 页 面 


Score. php 学 生成 绩 查询 页 面 。 系 统 起 始 仅 显示 查询 顶部 , 当 学 生 选 择 一 个 学 期 ,并 单 
击 “ 查 询 ” 按 钮 后 ,系统 才 会 显示 本 人 在 该 学 期 各 门 课程 的 成 绩 ,并 算出 总 分 和 平均 分 。 运 行 
界面 如 图 10-20 所 示 。 
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学 号 : 1530505101 ,姓名 : 李 凯 迷 2016-2017(2) 学 期 各 课程 成 绩 


























程 课程 名 称 分 歼 
0502040C 网 络 综合 布线 技术 67 
05020490 计算 机 英语 45 
0502050C PHP 课 程 设计 81 
0502080B AutoCad ( + 考证 ) 67 
0502231B java 程 序 设计 ( + 课程 设计 ) 34 
0502270B Linux 服 务 器 配置 与 管理 45 
0502730B | 网 络 安全 技术 100 
0502801B 网 络 互联 技术 92 

总 分 531 
平均 分 664 














10-20 ”学 生成 绩 查 询 页 面 
相关 代码 如 下 : 


<head> 
<meta http— equiv = "Content - Type" content = "text/html; charset = utf - 8" /> 
< link href ="../styles/com. css" rel = "stylesheet" /> 








<style type = "text/css"> 
table { 
width: 70%; 


margin: 0 auto; 
} 
</style> 
< script src=",./scripts/Com. js"></script > 
<title > 成绩 查询 </title > 
<div style = "Display:none"> 
<?php 
include "../Fun. php"; 
include "../IsLogin. php"; 
?> 
</div> 
< script language = " javascript"> 
function check( ) 
{ 
if(document. forml. term. value =="") 
{ alert(" 请 选择 学 期 !"); 
document. form1. term. focus( ); 
return false; 


</script > 
</head> 
<body> 
< form method = "post" name = "form1"> 
<divalign = "center">< font style = "font - family: ' 华 文 新 魏 '; font - size:20px"> 成 绩 查询 
</font><br> 
< select name = "term"> 








<option value =""> 请 选择 学 期 </option> 
<?php 

$ array = getdate(); 

$ year = $ array[ "year"]; 


$ month= $ array["mon" 
if ($month<= 7) for( $i=0; $i<3;$i++) 


{ 
echo "<option value= '".($ year— $i-—1)."—".($year— $i)."(2)'>" 
.($year—- $i—-1)."—".($year— $i)."(2)</option>"; 
echo "<option value= '".($ year— $i-1)."—".($year— $1)."(1)'>" 
.($year—- $i-—-1)."—".($year— $i)."(1)</option>"; 

} 

else for($i=0;$i<3;$i+t+) 

{ 
echo "<option value= '".($year— $i)."-—".($year— $1i+1)."(1)'>" 
.($year—- $i)."-—".($year— $i+1)."(1)</option>"; 


echo "<option value= '".($year- $i-1)."-—".($year- $1i)."(2)'>" 
.($year- $1i-1)."—".($year- $i)."(2)</option>"; 


?> 
</select> 
Snbsp; 
< input type = "submit" name = "search” value= "查询 ”onclick = "return check()"/> 
<?php 
if(isset( $_POST["search" ]) )// 单 击 查 询 专业 信息 
{ 
$userid= $ _SESSION["userid" ]; 
$ sql = "select * from student where studentid= '$ userid'"; 
$ rs=mysql_query( $ sql); 
$ row0 = mysql_fetch_array( $ rs); 
$ term= $ _POST["term"]; 
$sql = " select * from score, course where score. courseid = course. courseid and score. 
studentid= '$ userid'and offerterm= '$ term’"; 
$ result = mysql_query( $ sql); 
echo "< br /> 学 号 : ". $userid.", 姓 名 : ". $ row0[" studentname"]."&nbsp; &nbsp;". $ term. 
"学 期 各 课程 成 绩 "; 
i 
<table class= "tablel"> 
<thead> 
te> 
<th width= "30% "> 课程 号 </th> 
<th width = "50$% "> 课程 名 称 </th> 
<th width="20$ "> 分 数 </th> 
</tr> 
</thead> 
<?php 
$ count = 0; 
$ sum= 0; 
$row = mysql_fetch_array( $ result); // 数 组 的 键 名 可 以 是 整数 和 字段 名 
while( $ row) 





< 
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和 
<tr> 
<td width = "30 %"><?php echo $ row["courseid"];?></td> 
<td width= "50 % "><?php echo $ row["coursename"];?></td> 
<td width = "20 % "><?php echo $ row["score"];?></td> 
</tr> 
<?php 


$ count += 1; 
$ sum+= $ row["score"]; 
$ row = mysql_fetch _array( $ result); 
} 
if ( $ count >0) 
{ 
?> 
<tr> 
<td colspan = "2"> 总 分 </td> 
<td width= "20%"><?php echo $ sum; ?></td> 
</tr> 
丑 于 E> 
<td colspan = "2"> 平 均 分 </td> 
<td width = "20 多 "><?php echo round( $ sum/ $ count,1); ?></td> 
</tr> 
<?php 
} else{ 
?> 
<tr><td colspan = "3"> 暂 无 记录 </td> </tr> 
<?php 
}?> 
/table> 


<?php 


} 


?> 
</div> 
</form> 
</body > 


思考 与 练习 


1 
2 


3. 


4 


. 在 站 点 stu_project 根 目 录 下 创建 Changepwd. php 网 页 ,用 于 所 有 用 户 的 密码 修改 。 
. 根据 图 10-1 ,你 认为 各 个 文件 的 开发 顺序 是 怎样 的 ? 

为 什么 在 系统 入 口 页 面 Login. php 要 加 入 语句 session_destroy()? 

.在 Navicat_Premium 中 创建 数据 库 stu_db 和 8 个 数据 表 之 后 , 若 要 复制 数据 库 , 必 


须 先 做 什么 事情 ? 


第 1 章 PHP 开发 环境 


一 、 填 空 题 

1. ASP; JSP; PHP; ASP. NET 

2. IIS; Tomcat; Apache 

3. echo; isset() 

二 、 简 答 题 

1. 静态 网 页 中 只 有 HTML 标记 ,没有 其 他 可 执行 的 程序 代码 。 页 面 一 经 制作 完成 ,其 
内 容 就 不 会 再 变化 ,静态 网 页 的 扩展 名 一 般 为 . htm 或 . html。 动 态 网 页 是 指 " 具 有 交互 性 
的 页 面 ", 即 在 网 页 源 代码 不 变 的 情况 下 ,网 页 的 内 容 可 根据 访问 者 ,访问 时 间或 者 访问 目 
的 的 不 同 而 显示 不 同 的 内 容 , 如 留言 板 和 聊天 室 等 。 动 态 网 页 的 扩展 名 一 般 为 . asp、 jsp、 
.php、aspx。 

2. 略 。 


第 2 章 PHP 语言 基础 


一 、 填空 题 

1. HTML 标记 ; JavaScript 脚本 ; PHP 脚本 

2. 外 部 变量 ; $ _POST; $_GET; $_REQUEST 

二 、 简 答 题 

1. 使 用 单 引号 和 双 引 号 的 主要 区 别 是 : 单 引 号 内 出 现 的 变量 名 不 会 被 变量 内 容 代替 ， 
但 双 引 号 内 出 现 的 变量 名 会 被 变量 内 容 所 代替 。 

2. 上 略 

3. 12;14;16;18 
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第 3 章 PHP 数组 与 字符 串 


一 、 填空 题 
1. /[1-9J[0-9]{4,}/ 
2. /[0-9]{17}[L0-9XY]/ 
3. 可 以 ; 不 可 以 ; 0 
二 、 简 答 题 
1. $a[0][o],$a[o][1],$aLo][2],$a[1][o],$a[1][1,$a[l][2],$a[1][3] 
2. 代码 如 下 : 
<?php 
$x=array("keyl" =>1,"key2" =>2, "key3" =>3); 
$y=array("red", "blue", "white", "yellow"); 
extract( $ x); 
list( $a, $b, $c, $d)= $y; 
echo "$keyl $ key2 $ key3 "; 
echo"$a $b $c $d"; 
?> 


3， 代码 如 下 : 
<?php 
$a=5;$b=3;$c=100; $d=1; $e=12;$f£=200; 
$array = compact("a”, "b","c","d", "e","f"); // 使 用 变量 名 创建 数组 
sort( $ array); 
foreach( $ array as $ x) 
echo "$x"; 
?> 


第 4 章 PHP 面向 对 象 程序 设计 


一 、 填空 题 

1. 私有 的 ; 公有 的 

2.$ this 一 二 非 静态 成 员 ; 对 象 名 一 二 非 静 态 成 员 ; 类 名 : :静态 成 员 

3. 父 类 ; 接口 

二 、 简 答题 

1. 略 。 

2. 接口 与 抽象 类 的 区 别 如 下 : 

(1) 定义 接口 必须 省 略 abstract; 定义 抽象 类 必须 使 用 abstract。 

(2) 接口 中 只 能 包含 抽象 方法 , 且 抽 象 方法 必须 省 略 abstract; 抽象 类 中 可 包含 抽象 方 
法 与 非 抽 象 方法 ,而 抽象 方法 必须 使 用 abstract。 
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第 5 章 ”构建 PHP 互动 网 页 


一 、 填空 题 

1. 相同 ; 数组 ; 数组 

2. 24; session_set_cookie_params(60); 

3. 独 享 

二 、 简 答题 

1. 页 面 跳 转 的 方式 有 三 种 : 在 PHP 脚本 中 实现 页 面 跳 转 .在 HTML 标记 中 实现 页 面 
跳 转 、 在 JavaScript 脚本 中 实现 页 面 跳 转 。 

2. 在 PHP 中 实现 会 话 的 主要 步骤 如 下 。 

(1) 启动 会 话 。 

(2) 定义 会 话 变量 。 

(3) 访问 会 话 变量 。 

(4) 删除 会 话 变 量 。 

(5) 删除 会 话 。 


第 6 章 MySQL 数据 库 基 础 
一 、 填 空 题 


1，call 存储 过 程 名 ( 实 参 ) ;独立 于 ;插入 修改、 删除 ;基于 一 个 表 
2, 1s1;1 

3. new 

4. old 

二 、 简 答 题 


1，declare 语句 必须 放 在 存储 过 程 或 函数 中 的 首部 。 
2. 将 一 组 SQL 语句 ,以 一 个 名 称 存 储 在 数据 库 中 ,就 形成 存储 过 程 。 
创建 MySQL 存储 过 程 有 两 种 方法 : 一 种 是 使 用 查询 编辑 器 ; 男 一 种 是 使 用 函数 向 导 。 


3. after update old .new 
第 7 章 PHP 访问 MySQL 数据 库 


一 、 填空 题 

1. 连接 MySQL 服务 器 ; 选择 数据 库 ; 执行 SQL 语句 ; 关闭 连接 
2. 80; 3306 

3. 逐 行 获取 记录 ; 每 一 行 记录 ; 整数 

二 、 简 答题 

1. 制作 一 个 2 行 5 列 的 表格 

2. 制作 一 个 1 行 1 列 的 表格 
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第 8 章 ”PHP 常用 功能 模块 


一 、 填空 题 

1. 绝对 ; 相对 

2. 一 行 ; 源 代码 

3. echo time();; echo date('Y-m-d H.:i:s 1'); 
二 、 简 答题 

略 。 


第 9 章 PHP 安全 编程 


1. intval() 

2. SQL 注入 ,就 是 通过 把 SQL 命令 插入 到 Web 表单 递交 或 输入 域名 或 网 页 请 求 的 查 
询 字 符 串 ,最 终 达 到 欺骗 服务 器 执行 恶意 的 SQL 命令 。SQL 注入 攻击 的 主要 危害 包括 : 
非法 读 取 、 自 改 、 添 加 、 删 除数 据 库 中 的 数据 ; 盗 取 用 户 的 各 类 敏感 信息 ,获取 利益 ; 通过 修 
改 数据 库 来 修改 网 页 上 的 内 容 ; 私自 添加 或 删除 账号 ; 注入 木马 ; 等 等 。 

XSS 又 叫 CSS (Cross Site Script) , 跨 站 脚本 攻击 。 它 指 的 是 恶意 攻击 者 往 Web 页 面 
里 插入 恶意 HTML 代码 , 当 用 户 浏览 该 页 时 ,嵌入 其 中 Web 里 面 的 HTML 代码 会 被 执 
行 ,从 而 达到 恶意 攻击 用 户 的 特殊 目的 。XSS 攻击 的 危害 包括 : 盗 取 各 类 用 户 账 号 ,如 机 器 
登录 账号 .用户 网 银 账 号 、 各 类 管理 员 账 号 ;控制 企业 数据 ,包括 读 取 、 自 改 ,添加 、 删 除 企业 
敏感 数据 的 能 力 ; 盗 窃 企 业 重 要 的 具有 商业 价值 的 资料 ;非法 转账 ;强制 发 送 电子 邮件 ;网 站 
挂 马 ;控制 受害 者 机 器 向 其 他 网 站 发 起 攻击 。 

3. htmlentities 和 htmlspecialchars 的 功能 都 是 一 样 的 ,都 是 格式 化 html 代码 的 ,即将 
预定 义 的 字符 转化 为 HTML 实体 。 

两 者 区 别 : htmlentities 转换 所 有 的 HTML 标记 ,htmlspecialchars 只 格式 化 &、'、"、 
三 和 二 这 几 个 特殊 符号 。 


第 10 章 学 生 学 籍 成 绩 管理 系统 开发 实例 


1. 略 。 

2. 开发 顺序 一 般 为 : Login. php 一 Index. php 习 管理 员 子 系统 (教师 管理 ,班级 管理 、 学 
生 学 籍 管理 .课程 设置 管理 ` 开 课表 管理 ) 一 任课 教师 子 系统 中 的 模块 一 学 生子 系统 中 的 模 
块 一 管理 员 子 系统 (学 生成 绩 统 计 ) 

3. session_destroy() ;的 功能 是 删除 会 话 所 占 空间 。 因 为 各 子 系统 退出 时 ,都 返回 
Login. php 页 面 , 所 以 在 该 页 面 删除 所 有 的 会 话 变量 ,避免 用 户 的 账号 、 密 码 被 非法 使 用 。 

4. (1) 打开 数据 库 一 选择 “查询 ”~ "新 建 查询 ” 

(2) 在 查询 编辑 器 中 ,对 每 个 表 执行 语句 : 


alter table 表 名 ENGINE = MYISAM ROW_FORMAT = COMPACT; 
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